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(54) Method of enabling user access to services 

(57) A method and system for facilitating user ac- 
cess to services through a wireless device of a user, in- 
volves recommending to a user a subset of services 
from a plurality of services available to the user in which 
each recommended service of the subset has at least 



one voice short-cut associated therewith, and selecting 
a service to be accessed through the user's wireless de- 
vice from the subset of services according to a voice 
command by the user corresponding to the voice short- 
cut of the service. 
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Description 

[0001] The present invention relates to a method of enabling user access to services. 

[0002] Wireless devices are widely employed by people to access the growing number of available digital services. 

s Such access typically entails the utilization of a menu structure to enable a wireless user to identify the service of 
interest to be accessed. This is often a slow and cumbersome process. There are also well -known methods for a user 
to explicitly select short-cuts, i.e., "bookmarks", to their preferred services to facilitate quicker access. However, creation 
of such short -cuts requires significant effort on the part of the user, and organizing and accessing the short -cuts can 
be difficult in digital de vices with limited user interfaces (Ul). 

10 [0003] Moreover, in some situations, e.g. while driving a car, a user will be engaged in an activity which limits his or 
her ability to operate manually the digital device. In such situations, it would be desirable fo r the userto have alternative 
means by which to access services through the device, such as through voice command. However, speech recognition 
capability of existing technology suitable for wireless devices is limited in terms of different words a speech recognition 
engine can reliably identify. With the large number of different digital services now available to wireless users, it is not 

is feasible to reliably recognize a voice command to access what amounts to be a practically unlimited set of services. 
[0004] For example, in the case of (mobile) internet services (e.g., wml, html, xhtml pages) the amount of accessible 
services is almost unlimited. This means that it is generally not feasible to store the names of all the available services 
in mobile termina Is or in a centralized server. The mobile terminals simply do not have sufficient storage capacity. On 
the server side the storage capacity may not be a problem but it is not plausible that all (mobile) Internet services would 

20 register their names in a c entralized server. Even if all the services were registered, it would be very difficult for the 
user to uniquely indicate which service is requested. 

[0005] For example, if the user provides a voice command, "Yahoo news", it would be impossible for the central ized 
server to know which service is requested since the well known service site Yahoo provides news in many countries. 
Furthermore, knowing the language is not enough since Yahoo provides different news services for the different English 
25 speaking countries, such as the United States, the United Kingdom, Ireland, Singapore, Australia, New Zealand, and 
so forth. Concerning the United States, Yahoo further provides different services for different U.S. cities. 
[0006] The present invention seeks to provide an imp roved method of enabling user access to services. 
[0007] According to a first aspect of the present invention there is provided a method of enabling user access to 
services through a wireless device of a user, the method comprising recommending to a user a subs et of services 
30 from a plurality of services available to the user, each recommended service of the subset having at least one voice 
short -cut associated therewith; and selecting a service to be accessed through the user's wireless device from the 
subset of services according to a voice command by the user corresponding to the voice short -cut of the service. 
[0008] The plurality of services may comprise services previously accessed by the user. The recommended services 
may be transparent to the user. The method may further comprise visually outputting visual information corresponding 

35 to the subset of recommended services to the user. The visual information may include identification of a voice short 
-cut for each service of the subset of services. The visual information may include an icon to notify the user of the 
availability of voice access of the recommended services. The method may further comprise audibly outputting audio 
information corresponding to the subset of recommended services to the user. The audio information may include 
identification of a voice short -cut for each service of the subset of recommended services. The recommending may 

40 determine the subset of recommended services based on the user -related filter criteria. The recommending may 
determine the subset of recommended services based on a current context of the user. The current context may be 
inferred based on at least one of a temporal variable, a position variable and a selected profile of the device. The 
method may further comprise de termining the current context based on a current sensed environment of the wireless 
device. The recommending may determine the subset of recommended services based on a service usage history or 

45 preference of the user. The recommending may determine the su bset of recommended services based on the current 
environment of the wireless device sensed by one or more sensors. The sensor may be selected from the group 
consisting of a positioning sensor, a compass, a touch sensor, an audio sensor, a light sensor, and a temperature 
sensor. The method may further comprise obtaining voice short-cuts for a service in an XML format The method may 
further comprise assigning temporary voice short-cuts to the subset of recommended services. The method may further 

so comprise generating a voice short-cut for a service from the plurality of services based on metadata associated with 
the service. The method may further comprise enabling the user to predefine a voice shortcut for a service from the 
plurality of services. The m ethod may further comprise enabling the user to add or modify voice short -cuts for any 
one of the plurality of services. A voice short-cut for a service of the plurality of services may be predefined by the 
service provider. The method may further compri se receiving a voice short -cut for a service from a remote location, 

55 across a wireless network. The voice short -cut for a service may be received from a remote location, across an ad 
hoc wireless network including the wireless device. The voice short-cut for a service may be received from a voice tag 
registry, across a wireless network. The selecting may comprise performing voice recognition processing to identify 
the service with a voice short -cut matching the voice command. Voice recognition processing may be performed by 
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comparing the voice command only to voice short <uts of the recommended services. Voice recognition processing 
may be performed to identify the service with a voice short-cut matching the voice command according to a pnonty of 
the re commended services. Voice recognition processing may be performed by the wireless device. Voice recognition 
processing may be performed at a remote server and information identifying the selected service from the subset of 

5 recommended services is provide d by the remote server to the wireless device. The recommending of a subset of 
services maybe performed by the wireless device. Trie recommending of a subset of services may be performed at a 
remote server and information identifying the subset of recomme nded services is provided by the remote server to 
the wireless device. The selecting of a service is performed by the wireless device. The selecting of a service may be 
performed at a remote server and information identifying the selected service from the subset of recommended services 

to is provided by the remote server to the wireless device. The method may further comprise filtering down the subset of 
recommended services for selection according to past recommendations to the user. The method may further comprise 
filtering down the subset of recommended services for selection according to user-defined filter categories. The method 
may further comprise accessing the selected service using the wireless device across a wireless network. The method 
may furthe r comprise enabling multi -modal input, including at least voice input, to browse the accessed service. The 

is method may further comprise enabling multi-modal input selection, including at least by voice, of a service to be from 
the subset of recommended serv toes. The voice command may match a plurality of the recommended services and 
the method may further comprise outputting an indication of the matched services for selection by the user. The indi- 
cation of the matched services may comprise voice short-cuts corresponding to thereto. The method may further com- 
prise maintaining one or more databases of information corresponding to services and associated voice short -cuts. 

20 The method may further comprise interacting with at least one of a user input device and a user output device across 
a wireless short -range link. The voice short -cuts of the recommended services may change hierarchically according 
to a level of service. 

[0009] According to a second aspect of the present invention there is provided a method of facilitating multimodal 
access to services through a wireless device of a user, the method comprising recommending to a user a subset of 
25 services from a plurality of services available to the user, each recommended service of the subset having at least one 
voice short-cut associated therewith and selecting a service to be accessed through the user's wireless device from 
the subset of services according to a voice command by the user corresponding to the voice short ^cut of the service. 
[001 0] Facilitating multimodal acc ess may comprise facilitating multimodal access to services preferred by a user 
and may comprise facilitating multimodal short -cuts to digital services 
30 [001 1] According to a third aspect of the present invention there is provided a wireless device comprising vo ice mput 
device, output device, wireless interface for communicating across at least a wireless network and at least one proc- 
essor for recommending to a user a subset of services from a plurality of services available to the user, each recom- 
mended service of the subset having at least one voice short -cut associated therewith, and for selecting a service to 
be accessed through the user's wireless device from the subset of services according to the user's voice command 
35 received from the voice input device co (responding to the voice short -cut of the service. 

[0012] The plurality of services may comprise services previously accessed by the user. The recommended services 
may be transparent to the user. Visual information corresponding to the subset of recommended services may be 
visually output via the output device to the user. The visual information may include identification of a voice short -cut 
for each service of the subset of services. The visual information may include an icon to notify the user of the availa 
40 bility of voice access of the recommended services. Audio information corresponding to the subset of recommended 
services may be audibly output via the output device to the user. The audio information may include identification of a 
voice short -cut for each service of the subset of recommended services. The subset of recommended services may 
be determined based on the user-related filter criteria. The subset of recommended services may be determined based 
on a current context of the user. The current cont ext may be inferred based on at least one of a temporal variable, a 
45 position variable and a selected profile of the device. The processor may further determine the current context based 
on a current sensed environment of the wireless device. The subset of recommended services may be determined 
based on a service usage history or preference of the user. The wireless device may further compnse one or more 
sensors for sensing an environment of the wireless device, wherein the subset of recommended services may deter- 
mined based on a current environment of the wireless device sensed by the one or more sensors. The sensor may be 
so selected from the group consisting of a positioning sensor, a compass, a touch sensor, an audio sensor, a light sensor, 
and a tempera ture sensor. The voice short-cuts for a service may be received in an XML format via the wireless 
interface The processor may further assign temporary voice short -cuts to the subset of recommended services. The 
processor may further generate a voice sho rt«ut for a service from the plurality of services based on metadata asso- 
ciated with the service. The processor may further enable the user to predefine a voice short-cut for a service from the 
55 plurality of services. The processor may further enable the user to add or modify voice short -cuts for any one of the 
plurality of services. A voice short-cut for a service of the plurality of services may be predefined by the service provider. 
A voice shortcut for a service may be received from a remote location , across the wireless network. The voice short 
-cut for a service may be received from the remote location, across an ad hoc wireless network. The voice short -cut 
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for a service may be received from a voice tag registry, across a wireless network. The proc essor may perform voice 
recognition processing to identify the service with a voice short -cut matching the voice command. The processor may 
perform voice recognition processing by comparing the voice command only to the voice short-cuts of the recommended 
services. The voice recognition processing may be performed to identify the service with a voice short -cut matching 
5 the voice command according to a priority of the recommended services. The processor may further filter down the 
subset of recommended services for selection according to past recommendations to the user. The processor may 
further filter down the subset of recommended services for selection according to user-defined filter categories. The 
selected service may be accessed across the wireless network, via the wireless interface. The wireless device may 
further comprise a plurality of input devices, including the voice input device, wherein the processor further enables 
10 multi -modal input to browse the accessed service. The wireless device may further comprise a plurality of input devices, 
including the voice input device, wherein the processor enables multi -modal input selection, via the input devices, of 
a service to be accessed from the subset of recommended services. The voice command match es a plurality of the 
recommended services, the processor may further cause an indication of the matched services to be outputted for 
selection by the user. The indication of the matched services may comprise voice short -cuts corresponding to thereto. 
15 The wireless device may fu rther comprise memory for maintaining one or more databases of information corresponding 
to services and associated voice short -cuts. At least one of the voice input device and the output device may interact 
with the processor or oth er components of the wireless device across a wireless short -range link. The voice short 
-cuts of the recommended services may change hierarchically according to a level of service. 
[0013] According to a fourth aspect of the present invention there is provided a network system for enabling user 
20 access to services through a wireless device of a user, the system comprising a wireless device, a server and a wireless 
network infrastructure to enable communication between the wireless device and the server, the wirele ss device and 
the server cooperating (1) to determine a subset of services from a plurality of services available to the user, each 
recommended service of the subset having at least one voice short -cut associated therewith , and (2) to select a service 
to b e accessed through the wireless device from the subset of services according to the user's voice command, 
25 inputted to the wireless device, corresponding to the voice short -cut of the service. 

[001 4] The plurality of services may comprise services previously a ccessed by the user. The recommended services 
may be transparent to the user. Visual information corresponding to the subset of recommended services may be 
visually output at the wireless device to the user. The visual information may include identifica tion of a voice short -cut 
for each service of the subset of recommended services. The visual information may include an icon to notify the user 
30 of the availability of voice access of the recommended services. Audio information corresponding to the subset of 
recommended services may be audibly output at the wireless device to the user. The audio information may include 
identif ication of a voice short -cut for each service of the subset of recommended services. The subset of recommended 
services may be determined based on the user -related filter criteria. The subset of recommended services may be 
determined based on a current context of the user. The current context may be Inferred based on at least one of a 
35 temporal variable, a position variable and a se lected profile of the device. The processor may further determine the 
current context based on a current sensed environment of the wireless device. The subset of recommended services 
may be determined based on a service usage history or preference of the user. The wireless device may include one 
or more sensors for sensing a surrounding environment, the subset of recommended services may be determined 
based on a current environment of the wireless device sensed by the one or more sensors. The sensor may be selected 
40 from the group consisting of a positioning sensor, a compass, a touch sensor, an audio sensor, a light sensor, and a 
temperature sensor. The voice short-cut for a service may be received in an XML format via the wireless interface. 
The wireles s device may assign temporary voice short -cuts to the subset of recommended services. One of the 
wireless device and the server may generate a voice short -cut for a service from the plurality of services based on 
metadata associated with the service. The w ireless device may enable the user to predefine a voice short-cut for a 
45 service from the plurality of services. The wireless device may enable the user to add or modify voice short -cuts for 
any one of the plurality of services. A voice short-cut for a service of the plurality of services may be predefined by the 
service provider. The wireless device may receive a voice short -cut for a service from the server. The wireless device 
may receive the voice short -cut for a service from a remote location, across an ad hoc wireless network of the wireless 
network infrastructure. The wireless device may receive the voice short-cut for a service from a voice tag registry, via 
so the wireless network infrastructure. One of the wireless device and the server may perform voice recognition processing 
to identify the service with a voice short-cut matching the voice command. One of the wireless device and the server 
may perform voice recognition processing by comparing the voice command only to the voice short-cuts of the recom- 
mended services. The voice recognition processing may be performed to identify the service with a voice short -cut 
matching the voice command according to a priority of the recommended services. The wireless device may further 
55 fitter down the subset of recommended services for selection according to past recommendations to the user. The 
wireless device may further filter down the subset of recommended services for selection according to user-defined 
filter categories. The wireless device may access t he selected service across the wireless network infrastructure. The 
wireless device may include a plurality of input devices, including a voice input device and may enable multi -modal 
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input by the user to browse the accessed service. The wireless device may include comprising a plurality of input 
devices, including a voice input device, and may enable multi -modal input selection, via the input devices, of a service 
to be accessed from the subset of recommended services. The voice command may match a plura lity of the recom- 
mended services, the wireless device may further output an indication of the matched services for selection by the 

5 user Thee indication of the matched services may comprise voice short -cuts corresponding to thereto. The wireless 
device may further comprise memory for maintaining one or more databases of information corresponding to services 
and associated voice short -cuts. The wireless device may include at least one of the voice input device and the output 
device which are communicativ ely coupled thereto across a wireless short -range link. The voice short -cuts of the 
recommended services may change hierarchically according to a level of service. 

10 [0015] According to a fifth aspect of the present invention there is provided a system for enabling user access to 
services through a wireless device of a user, the system comprising a plurality of sensors for sensing an environment 
of a wireless device operated by a user, a context engine for determining a current context based on the sensed environ 
ment, a recommendation engine for recommending to the user a subset of services from a plurality of services previ- 
ously used by the user, each recommended service of the subset having at least one voice short -cut associated 

15 therewith, a voice recognition e ngine for receiving a voice command from the user and comparing the user's voice 
command to the voice short -cuts of the recommended service and a browser for accessing a service, from the subset 
of recommended services, with a voice short-cut matching the voice command. 

[001 6] According to a sixth aspect of the present invention there is provided a computer-readable medium encoded 
with processing instructions for implementing a method of enabling user access to services, performed by a computer, 
20 the method com prising recommending to a user a subset of services from a plurality of services available to the user, 
each recommended service of the subset having at least one voice short -cut associated therewith and selecting a 
service to be accessed through the user* s wireless device from the subset of services according to a voice command 
by the user corresponding to the voice short -cut of the service. 

[0017] Embodiments of the present invention will now be described, by way of example, with reference to the ac- 
25 companying dr awings in which: 

Fig. 1 is a network diagram, showing an example relationship between the user's portable wireless device, the 
protocol gateway to the Internet, the network server, a third party service provider, the Universal Description, Dis- 
covery and Integration (UDDI) registry, voice tag registry, and a plurality of web sites; 
30 Fig. 2A illustrates a simplified overview of the user's portable wireless device configured to perform context deter- 

mination , service recommendation and voice recognition so as to facilitate voice short-cut access to a recommend- 
ed service in accordance with one exemplary embodiment; 

Fig. 2B illustrates a simplified overview of a distributed system in which the context determination and service 
recommendation processing are of floaded to a network element, such as a network server, and the user's portable 

35 wireless device performs voice recognition processing of a user's voice command so as to facilitate voice short 

-cut access to a recommended service in accordance with a further exemplary embodiment; 
Fig. 2C illustrates a simplified overview of a distributed system in which the context determi nation, service recom- 
mendation and voice recognition processing are offloaded to a network element, such as a network server, so as 
to fa cilitate voice short-cut access to a recommended service in accordance with another exemplary embodiment; 

40 Rg. 2D illustrates a simplified overview of a distributed system in which the context determination and service 

recommendation processing are perfo rmed by the user's portable wireless device, and the voice recognition 
processing of a user's voice command is offloaded to a network element, such as a network server, so as to 
facilitate voice short -cut access to a recommended service in accordance with a further exemplary embodiment; 
Fig. 3A illustrates an example of the user's wireless device displaying a RECOMMENDATION WEB SERVICES 

45 MENU; 

Figs. 3B and 3C show an example of the user's wireless device displaying the SELECT SERVICE CATEGORY . 
sub -menu and the ENTER SPECIAL SERVICE REQUIREMENTS sub -menu, respectively; 
Figs. 3D and 3E show an example of the user's wireless device displaying the CHANGE STORED SERVICE 
PREFERENCES sub -menu and the CHANGE PRIVACY FILTER SETTINGS sub -menu, respectively; 
so Figs. 3F and 3G show an example of the user's wireless device displaying the LOCAL RECOMMENDATION sub 

-menu and the CHANGE VOICE SHORT -CUT sub-menu, respectively; 

Figs. 3H and 3! show an example of the user's wireless device displaying the recommendation results, for recom- 
mendations with no age restriction filter and for recommendations with a filter for family oriented subject matter, 
respectively; 

55 Fig. 3J shows an example of the user's wireless device displaying recommendation results in a menu form; 

Figs. 3K and 3L show examples of the user's wireless device displaying recommendation results in a hierarchical 
menu form; 

Fig. 4 illustrates and example of the service history log 110, with past recommendation and context files 227 and 
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with past service used and c ontext files 235; 

Fig. 4A is an exemplary network process diagram showing the interaction of the user's device 1 00 and the network 
server 140* 

Fig 4B is a flow diagram of an exemplary process in the network server 1 40 to respond to an updated menu reque 
st message from the wireless device 1 00, by compiling an updated menu which is returned to the wireless device 
100; 

Fig. 4C Is a flow diagram of an examplary process in the wireless device 100 to display the updated menu on the 
device's browser and proces s the user's request for a recommendation by gathering past received recommenda- 
tions from the service history log and pairing them with the current context of the device, and sending the context 
-activity pair in a recommendation request message to the net work server 140; 

Fig. 4D is a flow diagram of an exemplary process in the network server 140 to respond to the recommendation 
request message from the device 100, by accessing recommendations from the database corresponding to the 
current context, findi ng recommendations among those accessed from the database that are similar to the past 
received recommendations provided in the recommendation request message, sorting the found recommendations 
in accordance with the user's service preferences also provide d in the recommendation request message, and 
returning the resultant recommendations to the device 100 in a recommendation response message; 
Fig 4E is a flow diagram of an exemplary process in the wireless device 1 00 to filter the recommendations recerv 
ed in the recommendation response message and output the filtered recommendations on the device's browser, 
Fig. 4F is a flow diagram of an exemplary process in the network server 140 to respond to the recommendation 
request message from the device 100, by accessing recommendations from the database corresponding to the 
current context, finding recommendations among those accessed from the database that are similar to the past 
services used provided in the recommendation request message, sorting the found r ecommendations in accord- 
ance with the user's service preferences also provided in the recommendation request message, and returning 
the resultant recommendations to the device 100 in a recommendation response message; 
Fig. 4G is a flow diagram of an exemp lary process in the wireless device 1 00 to filter the recommendations received 
in the recommendation response message and output the filtered recommendations on the device's browser; 
Fig. 4H is a flow diagram of an exemplary process in the wireless device 100 to determine recommended services 
and to enable access to such services via voice short -cut; 

Fig. 41 Is a flow diagram of an exemplary process in the wireless device 100 to resolve multiple service matching 

issues either by priority or by allowing th e user to select from the plurality of matched services; 

Fig. 5 is a functional block diagram of an example of the wireless device 1 00, showing its various components and 

programs; 

Fig. 5A is an exemplary network process flow diagram of the interaction o f the wireless device 100 and network 
server 140 in which voice recognition processing of the user's voice command to select a service to access from 
the recommended services is performed by the network server 140; 

Fig. 6 is a functional block diagram of an example of the network server 140, showing the memory stonng the 
application services software programs needed to perform various operations, such as service recommendations 
and voice recognition; 

Fig. 7A is an exemplary process flow diagram by whic h the user is afforded the opportunity to define voice tags 
for services accessed for the first time; 

Fig. 7B is an exemplary process flow diagram by which the user is afforded the opportunity to add or modify voice 
tags for accessible services; and 

Fig. 7C is an exemplary database or data structure in a tree format showing the different hierarchical levels of 
service/sub -service along with their voice short -cuts. 

[001 8] A method and system for facilitating user access of services via a wireless device involve the combination of 
a service recommendation engine with voice or speech recognition technology to provide a user with voice, speech or 
verbal (hereinafter "voice") short -cuts to access preferred services, such as digital services, of the user. These serv 
ices may include, for example, web or WAP services, content described in XML language or other Internet -related 
languages (e.g., WML, HTML, XHTML, etc.), teletext or any type of service accessible by a mobile user through a 
wireless device. 

[0019] The service recommendation engine or algorithms (used interchangeably herein) are configured to recom- 
mend or determine a subset of services from a plurality of services according to user-related filter criteria. Such critena 
may be any factor unique or personal to th e user or the user's wireless device which can be utilized in ascertaining 
or inferring possible services preferred by a particular user. Examples of user -related filter criteria may include static 
or dynamic factors, such as the usef s service usage patt em or preference (e.g. , when, where, how, a number of times, 
etc. that a service was used); the selected profile of the device or user (e.g., the user's or device's charactenstics and 
preferences); the user's past and current activities; user's or device profile (e.g., the user's habits, likes -dislikes, per- 
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sonal characteristics, persona) background, activities, etc.); temporal variables (e.g., time of day, date, day of week, 
yea ^/nighttime, etc.). position variables (e.g.. location, at office, at home etc.). antforthe ^ or dev.es 
current context or environment which may be inferred from the user's perce^ed envnronment through one or more 
sensors (e.g., a positioning sensor, a compass, a touch sensor, an audio sensor a light sensor, and a temperature 

5 sensortandLotoerinformationsuchasnot^^^ 

[00201 Once a set of recommended services are deteimined. voice access to any one of these services may be 
accomplished thr ough use of voice recognition technology, for example, by comparing the user's inputted vo.ce com- 
mand to voice short «uts associated with the services. The voice short<ut(s) may be a phonetc express.on (e*. 
phoneme) associated with a service, and employed to enable voice shortcut to services through vo.ce reco gnrtion 

10 comparison of a user's voice command with the voce short -cuts of the services. The voce short -cut(s) for each 
servce may be obtained in a variety of ways, such as being generated from the attributes of the serve >"tf*~ 
g -host name- and/or 'service name") or other address attribute, or being generated from metadata associated wrth 
me service, or being defined by the user, service provider, voce registry or other system in t he form of a vo.ce Mag (e^ 
g Voice XML tag) for a service. The voice short-cut(s) may also be a "temporary" vo.ce short -cut assigned to a 

,5 Recommended service, such as according to a hierarchy or priority of f /^^^f 0 ^;^^^ *^ 
shortcut 'one- or T can be temporarily assigned to a first recommended serv.ce of the subset .thevo.ce short-cut 
two-or-2" can be temporarily assigned to a second recommended service ofthe subset, and so forth. The ma.ntenance 
and generation of voi ce short-cuts will be discussed in further detail below. 

[0021] Accordingly, through the above -noted combination, a wireless device may be configured wrth muta -modal 

20 nputtonctionalrtyo^ 

of user input (e.g., keypad, touch display, etc.), while reducing or minimizing the processmg load and memory ■ and 
otherhardware requirements necessary to implement such functionality or control in aw,relesedev,ce. Such an ar^ang 
lent does not require the user to remember the exact service addresses, which are often complex and d.fflcurt to 
remember, to access desired services; reduces privacy concerns for the user in the access of services; and provdes 

25 for service options which may be organized and accessed without requiring substantial effort on the .part of the >usen 
Such an arrangement further reduces voice recognition processing while increas.ng recognrt.on rel.ab.lrty through re- 
duction of the range of necessary voice short -cut comparisons. 

[0022] in one exempt embodiment, such a system and method are implemented through a portable , weless 
Lice including a recommendation engine, a votee recognition engine and a database of serves <«"^by 
so user. The recommendation en gine recommends or determines a subset of serves from a pluralrty of services to 
provide recommendations which are personal to and preferred by the user. The recommendation may be > based on 
Serious user-related filter criteria (e.g.. context) and. if des ired, limited to the range of past used semces of the user 
These recommended services may then be audibly or visibly outoutted to the user for select.cn thereof by ^voice o 
other form of user input, and such output may include information identifying t he voce short-cut(s) for one or more or 

35 each of the recommended services. .. .. j. .u„ «*- n i~, n nr 

[0023] For example, visual output of voice short «ut enabled services may be delayed in the form of an Icon or 
other visual forms (e.g., URL address) to inform the user of the availability of such shortcuts so as to ass.st the user 
in effect^ utilizing such short -cuts. This may ateo be accomplished by other output means such as audio ou tout 
[0024] Alternatively, the recommended services or voice short -cut enabled serv.ces may be transparent to the user, 
e o notoutputto the user. In such a case, determination of such recommended services may be triggered upon vanous 
events, such as periodically, at particular times/days/date, at particular locations, upon a manual command, upon a pa 
rticular activity, etc. or a combination thereof. 

[0025] in either case, the user may thereafter input a command by voice or other input forms to seled a sejx* .to 
be accessed from the subset of recommended services. When the input is a vo.ee command, the port able w.retess 
device, via the voice recognition engine, processes the voice command to an appropriate a computer readable torn* 
orother data form readable by aspeech decoder, compares the processed voice command data to voce short-cut(s) 
Lociated wrth the recommended servtees, and identffles the service wrth a voice short -cut matching the user's voce 
command. Thereafter, the portable wireless device, such as through its micro-browser, accesses the selected servce 

automatically or upon a user command. . , . „ 

so [0026] The recommendation engine may be configured to prioritize the recommendations or recommended services 
and to compare the votee command data with voice short -cuts according to a pnonty of the voce short -cut s) o 
associated recommended services. Thi s is particularly significant where a voice command may mateh a plura «y of 
recommended servtees. In such a case, the service with the higher priority is selected. Alternately, .n a srtuahon 
where a voice command may match a plurality of recommended services, an indication of the match.ng recommended 
55 services, such as their voce short -cuts, may be outoutted to the user for selection herefrom. notwftrVpd 
[0027] In another embodiment, the above system and method may be implemented through a debuted networked 
system in which various processing tasks and data maintenance may be ^buted between a por^le^wiretess device 
arid one or more network elements, such asanetwork server, ad hoc orshort -range wireless networked partner, and 
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so forth. The tasks may be distributed in the following manner. 

[1] The network server(s) or other network element may be configured to implement both the recommendation 
and voice recognition processing. For example, after initiation of the micro -browser by the user or other triggering 

s event, the wireless device receives a voice command from the user and forwards the voice command data to the 

network server and other relevant information, such as user -related filter criteria (e.g., context) and/or information 
for determining such criteria. The network server determines a subset of recommended services from a plurality 
of services based on the user -related filter criteria. The network server then, via voice recognition processing, 
identifies a service therefrom with a voice short -cut matching the user's voice command. The network server then 

10 returns information corresponding to the identified service, such as the service's address (e.g., URL) or other 
service access information, to the wireless device for access thereof. Alternatively, the network server may act as 
an intermediary between the wireless device and the service provider of the identified service and access the 
identified service for the wireless device. 

In another example, after initiation of the micro -browser by the user o r other triggering event, the wireless 

is device requests a service recommendation from a network server. The request may include other relevant infor- 

mation, such user -related filter criteria (e.g., context.) or information for determining such criteria. Th e network 
server receives the request along with any relevant information and determines a subset of recommended services 
from a plurality of services based on the user -related filter criteria. These recommendations are then sent to the 
wireless device wh ich outputs, audibly or visibly, the availability of such recommended services through voice or 

20 other user input short -cuts. 

The wireless device then receives the user's voice command and passes corresponding voice command data 
to the network server. Th e server then performs voice recognition processing on the voice command to identify 
a service (from the plurality of recommended services) with a voice short -cut matching the user's voice command. 
The network server then returns information corresponding to the identified service, such as the service's address 

25 (e.g., URL) or other service access information, to the wireless device for access thereof. Alternatively, the network 
server may act as an intermediary between the wireless device and the service provider of the identified service 
and access the identified service for the wireless device. 

[2] The network server(s) may be configured to implement the recommendation processing with the wireless device 
performing the voice recognition processing. For example, after initiation of the micro -browser by the user or other 

30 triggering event, the wireless device requests recommendations from a network server. The request may include 
other relevant information, such as user -related filter criteria or associate d information in determining such criteria. 
The network server receives the request and relevant information and determines a subset of recommended serv- 
ices from a plurality of services based on the user - related filter criteria. These selections are then sent to the 
wireless device, and the device outputs, audibly or visibly, the availability of such recommended services through 

35 voice or other user input short-cut. 

The wireless device then receives the user's voice command and performs voice recognition processing of 
the voice command to identify a service (from the plurality of recommended services) with a voice short -cut match- 
ing the user's voice command. Thereafter, the wireless device, via its micro -browser or other platform, accesses 
the selected s ervice automatically or upon the user command. 

40 [3] The network servers) or other network element may be configured to implement the voice recognition process- 

ing. For example, after the recommended services are audibly or visibly outputted to the user, t he wireless device 
receives a voice command from the user and forwards the voice command data to the network server and possibly 
other relevant information, such the recommended services information and/or voice short -cuts (e.g., voice XML 
tags) for such services. The network server, via voice recognition processing, identifies a service (from the plurality 

45 of recommended services) with a voice short -cut matching the user's voice command. The network server then 

returns information concerning the Identifi ed service, such as the service's address (e.g., URL) or other service 
access information, to the wireless device for access thereof. Alternatively, the network server may act as an 
intermediary between the wireless device and the provider of the identifi ed service and access the identified 
service for the wireless device. 

50 

[0028] In further embodiments, the maintenance and generation of voice short -cuts(s) for a particular digital service 
may be accomplished in various ways, for example, as follows: 

[A] Address attributes, such as host name and service name, or other portions of the address attributes may be 
& utilized as a voice short -cut of a digital service when performing voice recognition processing. 

[B] Voice short-cuts may be generated from metadata associate d with a particular service site. Metadata is often 
employed by search engines, service sites and/or other network entities to characterize or classify the content on 
a particular service site to facilitate user searches. Accordingly, one or more voice s hort-cuts may be generated 
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for association with a particular service according to the metadata associated with that service, such as by iden- 
tifying and selecting one or more words or terms from the metadata which aptly characterizes the service. This 
may be accomplished by manually examining the metadata associated with a service site, or through probability 
analysis in which the words or terms showing up a significant number of times or the greatest number of times is 
5 used as the voice short -cut. 

[C] A voice tag registry or the like may be maintained by a network element, such as a server, which maintains a 
relational database of service addresses and their associated voice tags. Voice tag registry may be similar to 
domain name registry, in which voice ta gs may be uniquely defined for a particular service using a standard format, 
such as in XML. Through a central registry, a uniform standard may be achieved for voice tags or the like and their 

io usage in enabling voice-access to associated services. A wire less device may request voice tags from the registry 
for the subset of recommended services prior to performing voice recognition processing. Alternatively, whenever 
a service site is accessed, the site may deliver the voice tag to the accessing device wh ich can store the voice 
tag for future use. 

Along similar lines, a service provider may predefine voice tags for its service addresses and provide such 
is information to the wireless device or other network elements in communication with the wireless device t o facilitate 
voice-based access to such service(s). For example, the service provider may embed voice tags in an XML mes- 
sage sent to the user's wireless device. 

[D] A user may define, change or delete voice short -cuts for a particular service which are stored locally on the 
user's wireless device or at a remote location accessible by the wireless device. 

20 [E] The wireless device generally may download predefined or generated voice short-cuts associated with services 

from a remote location, via a network. Such download may be performed when a new service is accessed by the 
user, at periodic intervals, upon a user request, or upon some other predetermined triggering event. 

[F] Voice short-cut(s) may also be a "temporary" short -cut assigned to a recommended service, such as according 
to hierarchy or priority of the recommendations. For example, the voice short-cut "one" or "1" can be temporarily 

25 assigned to a first recommended service of the subset, the voice short -cut "two" or "2" can be temporarily assigne 
d to a second recommended service of the subset, and so forth. Alternatively, the voice short -cut °A B can be 
temporarily assigned to a first recommended service of the subset, the voice short -cut "B M can be temporarily 
assigned to a second recommended ser vice of the subset, and so forth. Temporary voice short-cuts may be 
employed together with a selection menu, whether displayed or audibly outputted, for enabling voice short -cut to 

30 recommended services. 

[G] To specify a voice short -cut, voice tags may be used to categorize the voice short-cut for a particular service. 
For example, a voice short -cut may be tagged for a particular service in XML format ("voice XML tag"), e.g., 
<VOICE TAG> [voice -short cut] </VOICE TAG> to facilitate voice -access in a digital service environment, such 
as with Internet service, etc. 

35 

[0029] These and other exemplary embodiments will now be discussed in further detail below with reference to the 
Figures. Turning to Fig. 1 , an exemplary network environment is provided in which a user, operating a portable wireless 
device 100, is able to employ multi - modal input forms, such as voice along with other user input forms, to access 
preferred digital services through device 1 00. This is accomplished through combination of a service recommendation 

40 engine and a voice recognition engine, each of which may be implemented locally at the portable wireless device or 
at a remote location, such as at a network server 140, to provide voice short-cuts to the user's preferred services. 
[0030] The recommendation engine determines a subset of recommended services.from a plurality of services based 
on user -related filter criteria (e.g., context, etc.) and the voice recognition engine processes voice commands by the 
user to compare and match the voice commands to voice short-cuts associated with the recommended services to 

45 enable user selection and access of a service from the recommended services by voice short -cut. 

[0031] As shown, a network diagram illustrates an example of a relationship between the user's portable wireless 
device 100, a wireless access point 114, an infrastructure network 116, a network server 140, a voice tag registry 172 
and a third party service provider 1 80 interconnected over the Internet 1 30. The user's wireless device 1 00 communi- 
cates over a radio link with the wireless access point 114, which is connected to a wireless network 116, which is 

so connected to a protocol gateway 120. The gateway 120 is connected over the Internet 130 to the server 140. 

[0032] The network 105 formed by the wireless devic e 100, wireless access point 114, and infrastructure network 
1 1 6 can be implemented as a digital wireless wide area network (WAN), based on architectures such as Global System 
for Mobile Communication (GSM), IS - 1 36 TDMA-based Digital Advanced Mobile Phone Service (DAMPS), Personal 
Digital Cellular (PDC), IS-95 CDMA-based cdmaOne System, General Packet Radio Service (GPRS) and broadband 

55 wireless architectures such as W -CDMA and Broadband GPRS. For more information on these digital wireless, wide 
area networ k architectures, see the book by Yl -Bing Lin, et al. entitled Wireless and Mobile Network Architectures , 
John Wiley & Sons, 2001. The network 105 can also be a short -range wireless system connected to a wide area 
landline infrastructure network such as th e Internet 130. Short-range wireless systems include both wireless personal 
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area network ("PAN - ) and wireless local area network ("LAN"). Both of these networks have the common feature of 
operating in unlicensed portions of the radio spectrum, usually either in the 2.4 GHz Industrial, Scientific, and Medical 
(ISM) band or the 5 GHz Unlicensed-National Information Infrastructure ("U -Nil 0 ) band. Wireless personal area net- 
works use low cost, low power wireless devices that have a typical range often meters . The best-known example of 

5 wireless personal area network technology is the Bluetooth Standard, which operates in the 2.4 GHz ISM band. It 
provides a peak air link speed of one Mbps and a power consumption low enough for use in personal, portable electr 
onics such as PDAs and mobile phones. The Bluetooth Special Interest Group, Specification Of The Bluetooth System , 
Version 1 .OB, Volumes 1 and 2, December 1999, describes the principles of Bluetooth device operation and commu- 
nication protocols. Wireless 1 ocal area networks generally operate at higher peak speeds of from 1 0 to 1 00 Mbps and 

w have a longer range, which requires greater power consumption. Wireless local area networks are typically used as 
wireless links from portable laptop computers to a wire d LAN, via an access point (AP). Examples of wireless local 
area network technology includethe IEEE 802.1 1 Wireless LAN Standard and the HIPERLAN Standard, which operates 
in the 5 GHz U -Nil band. For more information on wireless LANs, see the book by Jim Geier entitled Wireless LANs , 
Macmillan Technical Publishing, 1 999. The network 1 05 formed by the wireless device 1 00, wireless access point 1 1 4, 

15 and infrastructure network 1 1 6 can use a wireless communications protocol, such as the Wireless Application Protocol 
(WAP), the l-Mode protocol, or the mobile IPv6 protocol. 

[0033] The portable wireless device 1 00 may take the form of a processor -based wireless communication-enabled 
device, such as a wireless mobile telephone, pager, two -way radio, smartphone, person al communicator, laptop or 
notebook computer, wireless personal digital assistant (PDA) or the like. The portable wireless device 100 includes a 

20 plurality of output subsystems, such as a displayed browser 1 02 and a speaker 1 07, to provide for multi -modal output 
functionality and a plurality of user input subsystems, such as microphone 103, keypad 104, a touch-display and so 
forth, to provide for multi -modal input functionality. The input and output devices of the wireless device may be inte- 
grated into the device itself and/or may be in communication with the device over a wireless connection, such as short 
-range wireless line (e.g., infra-red, radio link, etc.) 

25 [0034] The browser 102 may be partitioned, as desired, to have a main display area 102A and a voice short-cut 
indication display area 1 02B to display voice shortcut related information, such as in the form of an icon or other visual 
representation to notify the user of the availability of voice shortcuts to recommended services. Voice shortcut display 
ar ea 102B may also display the textual/character expression of the voice shortcuts to assist the user in learning such 
shortcuts or accessing services in a hands -free environment. The voice shortcuts or indications thereof may also be 

30 audibly output via voi ce response unit 118 in combination with the speaker 107, likewise, to notify the user of the 
availability of voice shortcuts and to assist the user in learning such short-cuts or accessing services in a hands -free 
environment. 

[0035] The portable wireless device 1 00 further includes various programs and databases, including the user's per- 
sonal programs and databases, programs and databases associated with the conventional operation of the wireless 

35 device, and programs and databases to implement the multi-modal short-cut service access processes discussed 
herein. These programs and databases may include, for example, application programs 1 06, communication programs 
1 08, service history log 1 1 0, current context state 111, recommendation algorithms or engine 1 1 2 to enable local and/ 
or network -based service recommendations, voice recognition engine (VRE) 113, and voice tag generator 119 for 
generating voice tags or generally voice short -cuts. These programs may further include a voice response unit (VRU) 

40 1 1 8 for conv erting data, such as text, to speech which can be outputted to the user via speaker 1 07. 

[0036] Voice recognition engine 112 may employ various well -known voice recognition techniques, for example, 
speech or speaker ("speech") independent recognition such as employed in speech independent name dialers (SINDs). 
Such speech independent recognition engine generally includes basic components, such as a front end, a dictionary, 
an acoustic model and a speech decoder. The front end converts speech into a data form sui table for analysis by a 

45 speech decoder. The dictionary maintains a list of words or phrases recognizable by the system, and may take the 
form of the service history log 1 1 0 which may maintain voice tags for associated services or take any other form suita 
bie to identify voice short -cuts for services available to the user. The acoustic model, in this example, may be an 
"isolated word" or "continuous" speech independent model based on Hidden Markov Modeling (HMM) to provide math- 
ematical representations of the words or phrases the system can recognize. Finally, the speech decoder compares 

so speech with the stored acoustic models to identify the most likely match between the speech and corresponding words 
or phrases in the dictionary. 

[0037] While speech independent recognition is preferably employed when speech recognition is to be performed 
by the mobile device, other well -known speech recognition techniques, such as speech -dependent recognition may 
also be employed by the mobile device or network server. 
55 [0038] The voice tag generator 1 1 9 is configured to provide generation of voice short - cuts, in the form of voice tags. 
The generator 119 may, for example, generate a voice tag for a particular service based on metadata associated with 
the services, such as metadata from the service provider, or other system (e.g., search engine provider). Generation 
of a voice tag may entail filtering or parsing the metadata to obtain a suitable phonetic expression (e.g., a phonetically 
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expressible term) which preferably characterizes t he service or the content of the service. For instance, the generator 
1 1 9 may determine the number of occurrences of particular terms in the metadata associated with a service site, and 
select the term(s) with the greatest number of occurrences as the voice short-cut for that service. Altemativefy, selection 
may be performed manually by an operator searching the metadata to select an appropriate term therefrom. 

5 [0039] As further shown in Fig. 1 , the portable wireless device 1 00 may also include a plurality of sensors for sensing 
the mobile user's ambient conditions. The sensors shown include POSITIONING SENSOR 122, TOUCH SENSOR 
124, AUDIO SENSOR 125, COMPASS SENSOR 126, AMBIENT LIGHT SENSOR 128, AMBIENT TEMPERATURE 
SENSOR 132, and THREE-AXIS ACCELERATION SENSOR 134. The audio sensor 125 can be a microphone, for 
example, which can detect speech or environmental sounds. The positioning sensor can be, for example, a GPS 

io receiver integrated in the device. The positioning sensor can also be, for example, a radio be aeon triangulation sensor 
that determines the location of the wireless device by means of a network of radio beacons, base stations, or access 
points, as is described for example, in Nokia European patent EP 0 767 594 A2, entitled "Mobile Station Positioning 
System". These sensors provide inputs which are sampled by the wireless device 1 00 to sense the user's environment, 
and one or more of these sensor outputs may be utilized to infer a current context which may be used to provide 

15 recommendations to the u ser based on the user's environment. The portable wireless device 1 00 may perform context 
inference techniques locally, or may offload to the network server 1 40 some of the computationally intensive computing 
involved in context inference techniques. 

[0040] For example, in one or more embodiments discussed herein, as the user carries about the wireless device 
100, its sensors may automatically and continuously measure the geographic location and context of the device. The 

20 wireless device may periodically transm it the current context in a message over the wireless network to the network 
server 140. There are several types of messages, each of which may be distinguished by its own unique op code. An 
"op code" is generally an operational code or instruction or co mmand which may be employed to inform or instruct 
other devices or network components, such as those discussed herein, of the operation to be performed. 
[0041] When the wireless device sends a message containing the current context, the network server 140 parses 

25 the op code and responds with information corresponding to the op code, the information being related to the current 
context. If the op code indicates that the message is a spontaneous message which is automatically transmitted by 
the device 100, then th e network server 140 may respond with information such as a service category menu, or 
information such as recommended services (along with their voice short -cuts) based on the current context, or prepaid 
advertising of local services related to the current context. 

30 [0042] As shown in Fig. 1 , the user's portable wireless device 100 further includes a service history log 110 or the 
like. The activities stored in the service history log 1 1 0 may be divided into two major categories: past recommendations 
made by t he wireless device 1 1 0 and/or network server 140, and services including their voice short -cuts (e.g., voice 
tags) or equivalents thereof for voice recognition matching. The category of services may be broken into four sub- 
categories: past services used, prestored service preferences, special requested service requirements, services and 

35 their associated voice short -cuts. The term "activities", as used herein, may refer to any of these categories and sub 
-categories. The service history log 1 1 0 may store five component databases: [1 ] past recommendations and context, 
[2] past services used and context, [3] prestored service preferences, [4] special requested service requirements, and 
[5] services and voice short-cuts. An example is shown in Fig. 4 of the t wo component databases: [1] past recommen- 
dations and context and [2] past services used and context. The voice short - cuts may also be maintained along with 

40 the associated services in service log 110, such as in the form of a voice XML tag. 

[0043] When implementing distributed processing with the network server 140, the wireless device 100 can auto- 
matically send messages with a unique op code designating that the message is an automatically transmitted message 
containing the device's past recommendations and context or past services used and context, in addition to the current 
context or other information for use in enabling voice short -cut access to recommended services. In one or more 

45 embodiments, the network server 1 40 may parse the op code and uses the devi ce's past recommendations and context 
or past services used and context to find similar service recommendations in its database. The network server 140 
then responds with information customized to the user's perceived interests, the inf ormation being rela ted to the current 
context. While the above discusses one approach to recommending services, any user -related filter criteria may be 
employed to determine recommendations personal to the user. 

so [0044] The user of the wireless device 100 can also manually enter r equests for menus and recommendations 
related to the current context. In any event, the wireless device 1 00 may then determine the service recommendations 
locally based on the current context and enable voice short-cut access to such recommended services. 
[0045] Alternatively, the wireless device 1 00 may send messages with a unique op code designating that the message 
is a manual request by the user containing the device's past recommendations and context or past services used and 

55 context, in addition to the c urrent context or other information for use in enabling voice short -cut access to recom- 
mended services. The network server parses the op code and uses the device's past recommendations and context 
or past services used and context to find similar recommen dations in its database consistent with the user's manual 
request. The network server 140 then responds with information customized to the user's expressed interests, the 
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information being related to the current context. While the above discusses one app roach to recommending services, 
any user -related filter criteria (as discussed herein) may be employed to determine customized or personalized rec- 
ommendations to the user. 

[0046] The service history log 1 1 0 can accumulate data on past services used by the user of the device 1 00 in several 

s ways. The service history log 110 can be programmed to capture on-line transactions and activities, such as ticket 
purchase information for services, access of a particular service as well as its sub -services, and so forth. Th e service 
history log 11 0 can also be programmed to monitor the dwell -time of the device at scheduled events and to draw the 
inference that the user is in fact engaged in such an event. The event and the current context and, if desired, associated 
voice s hort-cut(s) are then stored in the database [2] past services used and context, in the service history log 110. 

10 [0047] While the portable wireless device 1 00 may be configured to perform the context, recommendation and voice 
recognition processes alone, one or m ore or all of these processes can be offloaded to one or more other network 
elements, such as the network server 140. Accordingly, depending on which processes are offloaded, the network 
server 140 may include context inference engine 142, service and voi ce short-cuts database 143, voice tag generator 
145 (such as voice tag generator 119 discussed above), recommendation algorithms or engine 166, voice recognition 

15 engine 1 67 and/or context -activity pairs database 1 92. 

[0048] In one distributed system embodiment, the wireless device 100 provides recommendations to its user that 
are appropriate to the device's current environment by selecting an activity (e.g., a category or sub -category), pairing 
it with the current context result, and sending the context-activity pair to the network server 140. The network server 
140 searches its database of recommendations using the context -activity pair, and returns recommendations to the 

20 user. While the portable wireless device 1 00 and the network server 1 40 may employ context - activity pairs to determine 
recommended services, other user -related criteria and processes may be employed to ascertain preferred services 
desired to be accessed by the user. As such, a relational database or look -up table containing information on serv 
ices, voice short-cuts and user-related criteria can be maintained and updated accordingly to facilitate determination 
of recommendations and to enable voice short -cuts to the user's likely preferred services. 

25 [0049] Various embodiments showing how the processes to enable voice short-cuts to preferred services may be 
distributed between the wireless device 100 and the network server 140 are discussed below with reference to Figs, 
2A through 2D. 

[0050] Fig. 2A illustrates a simplified overview of the user's portable wir eless device 100 configured to perform 
context determination, service recommendation and voice recognition so as to facilitate voice short -cut access to a 
30 recommended service in accordance with one exemplary embodiment. As shown, the portable wireless dev ice 100 
may include a context inference engine 115, recommendation algorithms or engine 112, voice recognition engine 113 
and a database of services, such as service log 11 0, accessible by the user. 

[0051] The portable wireless device 100, in combination with context inference engine 11 5, are configured to deter- 
mine a current context based on the user's current context which, in turn, may be inferred through temporal information 

35 from an internal clock or from a network device, through sensory information from sensors of the device (e.g., location 
sensor, speed sensor, light sensor, sound sensor, etc.) such as a position of the user/device, through the user's activ- 
ities, through the setting or profile of the user or user's device, and so forth. The portable wireless device 100, in 
combination with the recommendation engine 112, determine and recommend a subset of services from a plurality of 
services based on user -related filter criteria, such as the current context or other personal factors (e.g., service usage 

40 history - those services utilized the most by the user, etc.). To reduce the workload of the wireless device, the searchable 
range of services may be limited to past used services. 

[0052] Once determined, these recommended services may then be audibly or vi sibly outputted to the user for 
selection thereof by voice or other form of user input, and such output may include information identifying the voice 
short -cut(s) for one or more or each of the recommended services. For example, visual output of voice sho rt-cut 
45 enabled services may be displayed in the form of an icon or other visual forms (e.g., URL address) to inform the user 
of the availability of such short -cuts so as to assist the user in effectively utilizing such short -cuts. This may also be 
accompl ished as well by other output means, such as audio output. 

[0053] The user may thereafter input a command by voice or other input forms to select a service to be accessed 
from the subset of recommended services. When the input is a voice command, the portable wi reless device 100, in 

so combination with the voice recognition engine 1 1 3, process the voice command to an appropriate a computer readable 
format such as for use by a speech decoder in performing comparisons or matching, compare the processed voice 
command data to voice short-cuts or the like of the recommended services, and identify or select the service (from the 
subset of recommended services) with a voice short -cut matching the user's voice command. Thereafter, the portable 
wireless device 100, such as t hrough its micro-browser 102, accesses the selected recommended service of service 

55 provider 205, automatically or upon a user command. 

[0054] Fig. 2B illustrates a simplified overview of a distributed system in which the context determination and service 
recomm endation processing are offloaded to a network element, such as the network server 140, and the user's 
portable wireless device 1 00 performs voice recognition processing of a user's voice command so as to facilitate voice 
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short-cut access to a recommendedservice in accordance with a further exemplary embodiment. As shown, the network 
server 140 may include context inference engine 142, the database 143 of services and their voice shortcuts or the 
like, and the recommendation engine 166; and the portable wireless device 1 00 may include voice recognrbon engine 
113 

[00551 In operation, after initiation of the micro -browser 1 02 by the user or upon some other triggering event, the 
portable wireless device 1 00 requests recommendations from the network server 1 40. The request may .nclude other 
relevant information, such as user -related fitter criteria or associated information in determining such crrtena The 
network server 140 receives the request and any relevant information and determines a subset of recommende d 
services from a plurality of services based on the user -related filter criteria. These selections are then sent back to 
the wireless device 1 00, and the device outputs, audibly or visibly, an indication of the availability of such recommended 
services t hrough voice or other user input short-cut. The voice short -cuts for the recommended services may be 
forwarded by the network server 140 or may be already stored locally for lookup on the portable wireless devce 100. 
[0056] The portable wireless device 100 rece fves the user's voice command and performs voice recognition process- 
ing of the voice command to identify a service (from the subset of recommended services) with a voice short -cut 
matching the user's voice command. Thereafter, the wireless device 1 00. such as via its micro -browser 1 02, accesses 
the selected service of service provider 205, automatically or upon the user command. 

[00571 Fig 2C illustrates a simplified overview of a distributed system in which the context determination, service 
recommendation and v oice recognition processing are offloaded to a network element, such as the network server 
140 so as to facilitate voice short -cut access to a recommended service in accordance with another exemplary em- 
bodiment. As shown, the network server 140 may inclu de the context inference engine 142 for determining a current 
context, the database 143 of services and their voice short -cuts or the like, the recommendation engine 1 66. and the 

voice recognition engine 1 67. .. . „ 

[00581 In one operational example, after initiation of the micro-browser 1 02 by the user or upon some other tnggenng 
event the portable wireless device 100 may request service recommendations from the network server 140. The 
request may include other relevant information, such us user-related fitter criteria or information for determining such 
criteria The network server 140 receives the request and any relevant information, and determines a subset of rec- 
ommended services from a plurality of services based on the user -related filter criteria. These selections are then sent 
back to the wireless device 100. and the device outputs, audibly or visibly, an indication of the ava.lab.lrty of such 
recommended services through voice or other user input short-cuts. 

[00591 The portable wireless device 1 00 then receives the user's voice command and passes corresponding voice 
command datatothe network server140 which performs voice recognition processing of the voice command to identify 
a service (from the subset of recommended services) with a voice short -cut matching the user's voice command The 
network server 140 then returns information on the identified service, such as the service address (e.g., URL) of the 
service site operated by service provider205 or otherservice access information, to the wireless device 110 1 far access 
thereof Alternatively, the network server 140 may act as an intermediary between the portable wireless device 100 
and the service provider 205 of the identified service and access the identified service for the wireless device. 
[00601 In an alternative example, after initiation of the micro -browser 1 02 by the user or upon some other tnggenng 
event the portable wireless device 110 receives a voice command from the user and forwards the voice command 
data to the network server 140, along with other relevant information, such as user -related filter cntena (ejj. context) 
and/orinformatlonfor determining such criteria. The network server 140 determines a subset of recommended servrces 
from a plurality of services based on the user -related filter criteria. Thereafter, the server, via voice recognrtion process- 
ing Identifies a service (from the subset of recommended services) with a voice short-cut matching the user's voice 
command. The network server 140 then returns information on the identified service, which may include the service 
address (e.g., URL) of the service site operated by service provider 205, to the wireless device for access thereof. 
Alternatively, the network server may act as an intermediary between the portable wireless device 1 00 and the service 
provider 205 of the Identified service and access the identified service for the wireless device. 
r00611 Fiq 2D illustrates a simplified overview of a distributed system in which the context determination and service 
recommendation process! ng are performed by the user's portable wireless device 100, and the "teuton 
processing of a user's voice command is offloaded to a network element, such as the network server 140, so as to 
facilitate voice short -cut access to a recommended servi ce in accordance with a further exemplary embodiment. As 
shown the portable wireless device 100 may include a context inference engine 115, recommendation algorrthms or 
engine 112, and a database of services and voice short -cuts thereto, such as service log 110; and the network server 
140 may include the voice recognrtion engine 1 67. K =*=w ™ 

[00621 In an operational example, the portable wireless device 100 determines recommended services based on 
user -related criteria and audibly or visibly outputs these recommendations to the user. The portable wireless devcelOO 
then receives the user's voice command and forwards the voice command data to the network server 140 along wrth 
other relevant information, such us the infoimation on the recommended services and/or voice s hort^uts (e.g., voice 
tags) for such services. 
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[0063] The network server 140, through voice recognition processing, identifies a service (from the subset of rec- 
ommended services) with a voice short -cut matching the user's voice command. The network server 140 then returns 
information on the identified service, which may include the service address (e.g., URL) of the service site operated 
by service provider 205, to the wireless device 110 for access thereof. Alternatively, the network server may act as an 
5 intermediary between the portable wireless device 1 00 and the service provider 205 of the identified service and access 
the identified service for the wireless device. 

[0064] To facilitate ease of use as well as to explain various functions enabled on the portable wireless device 100, 
a Recommendation Web Services menu may be provided and displayed on the browser 1 02 of the device. An example 
of such a menu as well as other screen shots of recommended services will be discussed below with reference to Figs. 
io 3Athrough3M. 

[0065] In Fig. 3A, the user's portable wireless device 100 includes the browser 102 which displays the Recommen- 
dation Web Services menu, to enable the user to navigate through the cards or pages being displayed and to select 
options that are programmed by the application programs 106. The browser 102 of the user's wireless device 100 
displays a recommendation web services menu. The recommendation web services menu may provide the user with 
is the following options to select: (A) REQUEST A RECOMMENDATION; (B) UPDATE PRIVACY FEATURES; and (C) 
MANAGE CONTEXT -ACTIVITY PROFILE. 

[0066] The REQUEST A RECOMMENDATION menu may display the following options: 
REQUEST A RECOMMENDATION: 

20 

[0067] 

[1] SELECT A SERVICE CATEGORY 

[2] SEND PAST RECOMMENDATIONS 
25 [3] SEND PAST SERVICES US ED 

[4] SEND PRESTORED SERVICE PREFERENCES 

[5] ENTER SPECIAL SERVICE REQUIREMENTS 

[6] CHANGE PRESTORED SERVICE PREFERENCES 

[7] CHANGE PRIVACY FILTER SETTINGS 
30 [8] LOCAL RECOMM ENDATION 

[9] CHANGE VOICE SHORT -CUT SETTINGS 

[0068] Reference to Fig. 4A illustrat e an example of how processes to be implemented at the wireless device 100 
or the network server 140 may be invoked through a menu selection, such as the menu of Fig. 3A. One or more of the 
35 processes to be discussed below, particularly the recommendation related processes, may alternatively be invoked 
upon initiation of browser 1 02, upon a user command, according to setting of the wireless device 1 00, or some other 
triggering event. 

[0069] As shown, the option 501 A to [1 ] SELECT A SERVICE CATEGORY invokes process 508 in the user's device 
1 00, to RETRIEVE UPDATED SERVICE CATEGORY M ENU , as shown in Figs. 4B and 4C. Process 508 sends updated 

40 menu request message 509 to process 608 in the network server 140, to UPDATE SERVICE CATEGORY MENU, as 
shown in Fig. 4B. The updated menu 225 (Fig. 3B) is returned in updated menu response message 509', as shown in 
Figs. 4B & 4C. The updated menu 225 is displayed in the device's browser 102 in Fig. 3A. This same sequence of 
steps is automatically performed by the wireless devi ce 100 and the network server 140 in response to the wireless 
device 1 00 automatically transmitting messages with a unique op code designating that the message is an automatically 

45 transmitted message. 

[0070] The option 501B to [2] SEND PAST RECEIVED RECOMMEND ATIONS invokes process 514 in the user's 
device 100, to SEND CONTEXT & PAST RECEIVED RECOMMENDATIONS, as shown in Figs. 4D & 4E. Process 
514 sends recommendation request message 51 5 to process 514 in the network server 140, to PROVIDE NEW REC- 
OMMENDATIONS CORRESPONDING TO PAST RECOMMENDATIONS, as shown in Fig. 4D. The recommendations 

so 250 are returned in recommendation response message 515', as shown in Fig. 4E. The recommendations 250 are 
displayed in the device's browser 102 in Fig. 3H. This same sequen ce of steps is automatically performed by the 
wireless device 100 and the network server 140 in response to the wireless device 100 automatically transmitting 
messages with a unique op code designating that the message is an automatically transmitted messa ge. 
[0071] The option 501 C to [3] SEND PAST SERVICES USED invokes process 520 in the user's device 1 00, to SEND 

55 CONTEXT AND PAST SERVICES USED, as shown in Figs. 4F & 4G. Process 520 sends recommendation request 
message 521 to process 620 in the network server 140, to PROVIDE NEW RECOMMENDATIONS CORRESPONDING 
TO PAST SERVICES USED, as shown in Fig. 4F. The recommendations 250 are returned in recommendation response 
message 52V, as shown in Fig. 4G. The recommendations 250 are displayed in the device's browse r 102 in Fig. 3H. 
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This same sequence of steps is automaticany performed by the wireless device 100 and the network server 140 in 
response to the wireless device 100 automatically transmitting messages with a unique op code designating that the 
message is an automatically transmitted message. 

[00721 The option 501 D to [4] SEND PRESTORED SERVICE PREFERENCES invokes process 510 in the user's 
5 device 100, to SEND CONTEXT AND PRESTORED SERVICE PREFERENCES in the prestored service preferences 
file 231 , as shown in Fig s. 4D & 4F. An example of prestored service preferences is shown displayed in the browser 
102 of Fig. 3D. Process 510 sends message 511 to process 610 in the network server 140, to PROVIDE RECOM- 
MENDATIONS CORRESPONDING TO SERVICE PREFERENCES. The recommendations 250 are returned in mes- 
sage 52V. 

10 [0073] The option 501 E to [5] ENTER SPECIAL SERVICE REQUIREMENTS invokes process 512 in the user's 
device 100, to SEND CONTEXT AND SPECIAL SERVICE REQUIREMENTS. An example of special service require- 
ments is shown di splayed in the browser 102 of Fig. 3C. Process 512 sends message 513 to process 612 in the 
network server 140, to PROVIDE RECOMMENDATIONS CORRESPONDING TO SPECIAL REQUIREMENTS. The 
recommendations 250 are returned in message 521 '. 

15 [0074] The option 501 F to [6] CHANGE PRESTORED SERVICE PREFERENCES invokes process 51 6 in the user's 
device 1 00, to CHANGE PRESTORED SERVICE PREFERENCES. An example of a menu to change prestored service 
preferences is shown displayed in the browser 1 02 of Fig. 3D. 

[0075] The option 501 G to [7] CHANGE PRIVACY FILTER SETTINGS invokes process 518 in the user's device 
100, to CHANGE PRIVACY FILTER SETTINGS. An example of a menu to change privacy filter settings is shown 

20 displayed in the browser 1 02 of Fig. 3E. 

[0076] The option 501H to [8] LOCA L RECOMMENDATION invokes process 519 in the user's device, to initiate 
LOCAL RECOMMENDATION, e.g., to determine service recommendations locally at the user's device. An example 
of a menu to initiate local recommendation is shown displayed in the browser 1 02 of Fig. 3F. The local recommendations 
may be determined from a database of [a] past used services or [b] downloaded services from a network server, such 

25 as server 1 40. An example of service recommendations displayed on the browser 1 02 is shown in Figs. 3H through 3L. 
[0077] The option 501 1 to [9] CHANGE VOICE SHORT -CUT SETTINGS invokes process 525 in the user's device 
to initiate CHANGE VOICE SHORT -CUT SETTINGS. An example of a menu to initiate change in voice short -cut 
settings is shown displayed in the browser of Fig. 3G. These settings may include [a] downloading voice tags from 
server 140, voice registry or other remote location, [b] adding, modifying and/or deleting voice tag for a particular 

30 service, [c] setting a language preference for voice tag (e .g., English, French, Japanese, etc.) to facilitate voice rec- 
ognition processing, [d] setting voice tag output ON or OFF, and so forth. While the above are discussed for voice tags, 
these setting equally apply generally to voice short-cuts. 

[0078] As the user carries about the wireless device 100, its sensors 122- 134 continuously measure the geographic 
location and context of the device, which are compiled into a metadata vector 138 representing the current context. 

35 The wireless device 1 00 periodically transmits the current context in an updated menu request message 509, shown 
in Fig. 4B, over the wireless network 1 05 to the network server 140. The updated menu request message 509 includes 
the network address of the server 1 40, an op code value RQ_MN that des ignates the message as an updated menu 
request message, and an operand portion containing the current context. The network server 1 40 of Fig. 4B includes 
a server op code parser 21 6 that interprets the op code value RQ_MN as indicating that the message is an updated 

40 menu request message 509. In response, the server op code parser 21 6 invokes step 21 8 of the server recommendation 
algorithms 1 66. Step 21 8 gets from a database a list of services provided by regional advertisers corresponding to the 
current context of the device 1 00. Step 21 8 flows to step 220, which gets from a database a list of services provided 
by regional points of interest, such as galleries, monuments, museums, and the like, corresponding to the current 
context of the device 1 00. St cp 220 flows to step 222, where the list of services provided by regional advertisers and 

45 the list of services provided by regional points of interest are filtered for weather related and time related service 
categories, eliminating those services that can not be used by the user in the current context. For example, night 
baseball is eliminated, if the current context is daytime. Hiking a nature trail is eliminated if the current context is bad 
weather. Likewise, in a digital service scenario, electronic stock trading may be eliminated, if the current context is 
nighttime. Step 222 flows to step 224, where the updated menu message 509' is prepared. The updated menu message 

50 509' includes the network address of the device 1 00, an op code "RSP.MN 0 that designates the message as an updated 
menu server response message, and operands. The operands include the updated menu 225. The updated menu 225 
is returned to the device 1 00 in the updated menu response message 509', as shown in Figs. 4B and 4C. This same 
sequence of steps is automatically performed by the wireless device 100 and the network server 140 in response to 
the wireless device 100 automatically transmitting messages with a unique op code designating that the message is 

55 an automatically transmitted message. 

[0079] The device op code parser 214 in Fig. 4C interprets the op code value a RSP_MN" as indicating that the 
message is an updated menu server response 509'. In response, the device op code parser 214 invokes step 226 of 
the device recommendation algor ithms 112. Step 226 stores and displays the updated menu 225 in the device's 
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browser 102 in Fig. 3B. 

[0080] The user can initialize the device 100 by entering special service requirements as shown in the browser 1 02 
of Fig. 3C. Examples of special service requi rements that can be stored in the service history log 1 1 0 of device 1 00 are: 

5 [a] AGE REQUIREMENT: 

ALL AGES/CHILD AGE RANGE/ ADULTS ONLY 

[b] TIME OF DAY REQUIREMENT: 

10 

EARLIEST/LATEST 

[c] MAX WALKING DISTANCE 

[d] PRICE RANGE 

15 [e] PREFERRED DRESS: 

CASUAL/DRESSY/FORMAL 
[f] HANDICAPPED FACILITIES: 

20 

RAMPS/HAND RAILS/REST ROOMS. 

[0081] The user can initialize the device 100 by entering stored service preferences, as shown in the browser 102 
of Fig. 3D. Examples of stored service preferences that can be stored in the service history log 110 of device 100 are: 

25 

GALLERIES [modem art] 

MONUMENTS [maritime history] 

MOVIES [family oriented] 

MUSEUMS [technology; natural history] 
30 MUSIC Qazz] 

NIGHT LIFE [professional sports] 

OUTDOORS/FITNESS [sailing; cycling] 

RESTAURANTS [casual] 

THEATER [orchestral] 
35 NEWS [sports] 

[0082] The user can initialize the device 1 00 by entering privacy filter settings, as shown in the browser 1 02 of Fig. 
3E. Privacy filter settings are used to remove the user's private information from the m essages sent by the device 1 00 
to the network server 1 40. Examples of privacy filter settings that can be stored in the device 1 00 are: 
40 [0083] FOR CURRENT REQUESTS: 

[a] REMOVE USER NAME 

[b] ENTER OTHER DATA TO REMOVE 

45 [0084] FOR PAST RECOMMENDATIONS: 

[a] REMOVE USER NAME 

[b] REMOVE LOCATION OF PAST RECOMMENDATION 

[c] REMOVE DATE OF PAST RECOMMENDATION 
so [d] REMOVE NAME OF PAST SERVICE PROVIDER 

[e] ENTER OTHER DATA TO REMOVE 

[0085] The service history log 1 1 0 in the user's device 1 00 may store activities in five component databases: [1 ] past 
recommendations and context, [2] past services used and context, [3] prestored service preferences, [4] special re- 
55 quested service requirements, and [5] services and voice short-cuts. An example is shown in Fig. 4 of the two com- 
ponent d atabases: [1] past recommendations and context 227 and [2] past services used and context 235. The em- 
bodiment of the database shown in Fig. 4 uses extensible markup language (XML) files to provide a coherent view of 
the wide variety of data that can be us ed to characterize a contexts, services, recommendations, and voice short -cuts. 
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[0086] To specify the current context, XML tags are used to categorize each type of context data that characterizes 
the current context. Each unit context data is delineated by a beginning tag and an ending tag, forming an element. 
For example, the element •<TEMPERATURE>1 0 degrees Ceisius</TEMPERATURE >" defines the category as tem- 
perature, and specifies the data as "10 degrees Celsius'. As another example, the element "<LAT>38 degrees, 48 
minutes North </LAT>" defines the category as geographic latitude, and specifies the data as "38 degrees, 48 minutes 
North 0 . Another feature of XML is its ability to specify a hierarchy in the categories of data. For example, geographic 
locati on is normally specified as both a latitude and a longitude. The categories of data for latitude and longitude can 
be thought of as "child" categories within the category for geographic location. XML expresses this hierarchy as follows: 

<LOCATION> 

<LAT>38 degrees, 48 minutes NortlK/LAT^ 
<LON>76 degrees, 38 minutes West</LON> 

<LOCATION> 

[0087] A typical specification of the context for an activity stored in the service history log 11 0 would be, for example: 

<CONTEXT> 

<LOCATION> 

<LAT>38 degrees, 48 minu tes North</LAT> 

<LON>76 degrees, 38 minutes WesK/LON> 

<ALT>150 meters</ALT > 
/LOCATION > 

<DATE>2001 :01 :3 !</ DATE > 
<TIME>120D</riME> 

<TEMPERATURE>1 0 degrees Celsius ^TEMPERATURE > 
</CONTEXT> 

[0088] A typical specification of the voice short for servic e stored in the service history log 1 1 0 may be, for example: 
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<NAME> 

<HOSTNAME> HistoryMuseum.conK/HOSTNAME> 
<SERVICENAME>/exhibits.wml/</SERVTCE NAME> 
<VOICETAG>History<A^OICETAG> 
</NAME> 

[00891 By expressing the context in the service history log 110 in XML, the stored expression Is both human and 
EL Saddle, it defines the content, and it defines the hierarchical structure of the content. XML also ^separate 
the appearance of thecontent from the structure of the content, so thatthe content can be *^ m W*™«» 
using customs style sheets in each different type of display device. Extensile Stylesheet Language XSL) can 
povLflexibledocumentpresentation.enab.ing thecontent of an XMLfile to be ^ n TT>XZ7e 
of a persona, computer, as well as in the browser 1 02. Messages exchanged between the w,reless M MOO and the 
network server 140 can include XML files carried in the Simple Object Access Protoco I (SOAP ) ™«W pr**o' 
or the SyncML synchronization protocol . For additional background on XML. see the book by Heather Williamson. 
XML- The Com plete Reference , Osbome/McGraw-Hill. 2001 . .„ ^ 

[0090] Boththewirelessdevic e 1 00 and the network server 1 40 may be configured to interpret the tegs of the , XML 
eleme nts in the XML file in the same way. This can be accomplished by incorporating the same XML ta , parser* 
both the device recommendation algorithms 112 of the wireless device 100 and in the server 
rithms 166 of the network server 140. In its simplest form, the XML tag parser can be a s.mple string comparison 
TZ I arches the XML file for XML tag strings, such as the beginning tag "^OCATION^ and the ending teg 
■</LOCATION>-. When it finds the a particular beginning teg, it gets the data located between the beginning tag and 
the ending teg and passes the date as "location date" to program subroutines that operate on location , data. Such 
program subroutines include the database search routine in the server recommendation a Igon thms 166 in the server 
140 Jthatformsaquery from the latitude and longitude date to search for recommendations for services in the database 
192 having similar or related to the latitude and longitude values. ¥U1 
0091] Another way for both the wireless devk* 10 0 and the network server 1 40 to interpret the tegs of the XML 
elements in the XML file in the same way. is by means of a standard XML parser. The two Pnn«PaL stendar d XML 
parsers are the Simple API for XML (SAX) event-based parser and the Document Object Model (DOM ^ee -based 
parser. The principal deference between them is in the way the XML data is made ava able to the chen t-PPWn. 
such as the devk* recommendation algorithms 112. SAX is an event driven model, where.r .the Cent app catio , « 
continuously notified as the XML document features are recognized by the parser. As the SAX parser reads an XML 
St e d^to the application program 112 information from the XML file in real tima Each time the parser sees , a 
beginning tag.anendingteg.characterdate.oraprocessinginstruction.it reports 

XML file does not have to be read before acting on the data at the beginning of the file. The entire document does not 
have to reside in memory, which can be an advantage for the wireless device 100 

[0092] The Document Object Model (DOM) model parser is object based, on the other hand, wherein the entire XML 
document is parsed and stored as a hierarchical tree of objects that the client application can Jhen ™<^«»"*- 
A document type definition (DTD) is available to both the wireless device 100 and ,n the "etworic server 140 . either 
being stored kLlly or at a server they can reference. A DTD is a set of declarations that spec-Jr *e allowed ord e, 
structure, and meaning of the tags for a particular XML fi.e. The XML file references the DTD that governs to orter 
structure and meaning, at a specified location, such as the directory of the local f.lesystem, and its filename as a 
hanore Stenda rd XML parsers are part of many operating systems now available. A DOM tree -based parser eada 
in the DTD and the XML file and converts the XML file into programming cons ^^^^^'^. 8 ^ 
Adocumenttype declaration element must appear in the XMLfile to indicate DTD to wh«h the X^ 
and where to find rt. It starts with -<DOCTYPE- and ends with V. The example given below is <DOCTYPE OBJECT 

[ooiif ^ach XMLfMfbegins with a processin g instruction that grves information to an XML P™** 0 '*^** 
Ess device 1 00 and the network server 1 40. ft starts with ■<?' and ends with V. The example g *en below ,s <? 
XML VERSION= u 1 0 P ?> 

[0094] An example of a complete XML file specifying a past recommendation received by the device 100 and the 
Ext in whfch it was received is shown in the following TABLE A, which is the XML file 227 taken from the serv«e 
history log 110 of Fig. 4. 
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TABLE A- Example of an XML File Specifying a Past Re commendation 
<?XML VERSION="1.0 n ?> 

<DOCTYPE PAST_RECOMMENDATIONS_OBJECT "xml.directory \objectdtd">. 
<PAST_RECOMMENDATIONS - OBJECI> 

<DESCRIPTION>Past Recommendation</DESCRIPTION> 

<PLACE-EVENTS>Museums</PLACE -EVENTS > 
<PASTJlECOMMENDATIONS> 

<NAME> 

<HOSTNAME> HistoryMuseum.com</HOSTNAME> 
<SERVICENAME>/exhibits.wml/</SERVICE NAME> 
<VOICETAG>History<yVOICETAG> 

</NAME> 
<CONTEXT> 

. <£CATION> 

<LAT>38 degrees, 48 minutes North</LAT> 
<LON>76 degrees, 38 minutes West</L0N> 
<ALT>150 meters</ALT > 

^/LOCATION > 

<DATE>2001:01:31</DATE > 

<rnME>1200</nME> 

<TEMPERATURE>10</TEMPERATURE> 

<MET AVECTOR>FF 1 2 AB34CD</MET AVECTOR> 
</CONTEXT> 

</PAST_RECOMMENDATIONS> 
<l PAST_RECOMMENDATIONS_OBJECT> 
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[0095] An abbreviated example of a corresponding document type definition (DTD ) that specifies the allowed order, 
structure, and meaning of the tags for a past recommendation XML file, is shown in the following TABLE B. This is part 
of a file named "object.dtd" stored in the local filesystem directory named ■xmLdirectory" in both the wireless device 
100 and the network server 140. It illustrates, for example, that the PAST.RECOMMENDATIONS element must include 
5 the NAME of the past recommended service, and the CONTEXT in which it was recommended. The NAME element 
must include the HOSTNAME, the SERVICENAME, and the VOICETAG. The CONTEXT element must include the 
LOCATION, the DATE, the TIME, the TEMPERATURE, and the METAVECTOR containing the metadata vector 138 
characterizing the context of device. The LOCATION element must inclu de latitude LAT, the longitude LON, and the 
altitude ALT of the device. 

w 

TABLE B - 

Abbreviated Example of a Document Type Definition (DTD) 
<!ELEMENT PASTER ECOMM EN DATION SJDBJECT ( DESCRIPTION, PLACE -EVENTS, 
PAST.RECOMMENDATIONS )> 
,5 <IELEMENT PAST_R ECOMM EN DATIONS (NAME, SERVICE, CONTEXT)> 
<!ELEMENT NAME (HOSTNAME, SERVICENAME, VOICETAG) > 
<IELEMENT CONTEXT (LOCATION, DATE, TIME, TEMPERATURE, METAVECTOR)> 
<!ELEMENT LOCATION (LAT, LON, AL7> 

In a complete DTD for the XML file of TABLE A, the data elements, such as 
"<LAT>38 degrees, 48 minutes North </LAT> B would be specified in the DTD as 

"<! ELEMENT LAT (#PCDATA)>* to indicate that these elements are present and contain only data, and do not 
contain other elements. 

25 [0096] Great flexibility is provided by the use of XML to define the data to be included in the files of the five component 
databases of the service history log 110: [1] past recommendations and context, [2] past services used and context, 
[3] prestored service preferences, [4] special requested service r equirements and [5] services and voice short -cuts 
(e.g., voice tags). These XML files can be readily identified, accessed, and their elements parsed to obtain the relevant 
data pertaining to each category. The meaning of the data is assured by its location in a known element type. The XML 

30 files, themselves, can be included in the messages exchanged between the wireless device 1 00 and the network server 
140.' This can be seen in the following discussion of the process 514 in the wireless device 100 of F ig. 4C, to process 
the user's request or generally a request by the wireless device 100 for a recommendation by gathering XML files 227 
of past received recommendations from the service history log 110 and pairing them with the current context of the 
devic e. The context-activity pair is then sent in a recommendation request message 515 to the network server 140. 

35 [0097] In Fig. 3A, the user selects the option [2] SEND PAST RECEIVED RECOMMENDATIONS. Then, in Fig. 3B, 
the user selects the service category of "GALLERIES" from the service category menu 225. Then in Fig. 4C, step 228, 
the wireless device 100 receives the user's input and flows to step 230 to get the current context. The process then 
flows to step 232 to access the service history log 110 for XML fil es 227 of past received recommendations. The 
process then flows to step 234 to apply privacy filter settings 229 to the data in the XML files 227. For example, step 

40 234 can remove any occurrence of the user's name, the location of past recommendations, the date of past recom- 
mendations, the name of past service providers, and the like. Then, the recommendation request message 515 is 
assembled. The recommendation request message 515 includes the network address of the server 140, an op code 
"RQ_REC_3 H th at designates the message as a recommendation request message, and the operands. The operands 
include the current context expressed in a separate field as the metadata vector 138, the past recommendation and 

45 context XML file 227\ and the prestored servic e preferences XML file 231 . The wireless device 1 00 then sends rec- 
ommendation request message 515 to the network server 140, as shown in Fig. 4D. 

[0098] Fig. 4D is a flow diagram of the process in the network server 140 to respond to the recommendation request 
message 515 from the device 100. The network server 140 of Fig. 4D includes the server op code parser 216 that 
interprets the op code value "RQ_REC_3° as indicating that the message is a recommendation request message 515. 

so In response, the server op code parser 21 6 invokes step 240 of the server recommendation algorithms 1 66. Step 240 
receives the metadata vector 138 from the message 515 and accesses or determines recommendations from the 
database 1 92 corresponding to the current context. The process may then flows to step 242, if desired, which searches 
through the accessed recommendations obtained from the database to find those similar to the past received recom- 
mendations 22/ input from the message 51 5. The process then flows to step 244 which sor ts the similar recommen- 

55 dations in accordance with the user's preferences 231 , also received in the message 51 5. The user's preferences 231 
is shown as the example XML file of TABLE C, as follows: 
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TABLE C- Example of an XML File Specifying User Preference s 
<?XML VERSION= n l .0"?> 

5 

< PREFERENCES_OBJECT> 

<DESOUPTI0N>Prefenm^ 

10 

<GALLERIES>Modem Art</GALLERIES> 
<MONUMENTS>Maritime</MONUMENTS> 
15 <MOVIES>Family Oriented</MOVIES> 

</PREFERENCES_OBJECT> 

20 other user preferences objects or combinations the reof instead of those shown above in Table C may also be employed, 
e.g., NEWS, etc. 

[0099] The process then flows to step 246 which updates usage statistics and stores them in a database. The process 
then flows to step 248 which assembles the recommendation res ponse message 515* and transmits it back to the 
wireless device 1 00. The recommendation response message 51 5' includes the network address of the wireless device 
25 100, the op code °REC_3" that designates the message as a recommendation response message, an d the operands. 
The operands include the recommendations XML file 250. 

[0100] Fig. 4E is a flow diagram of a process in the wireless device 100 to filter the recommendations received in 
the recommendation response message and display the filtered recommendations on the device's browser. The device 
op code parser 21 4 in Fig. 4E interprets the op code value "REC_3" as indicating that the message is a recommendation 

so response message 515'. In response, the device op code parser 214 invokes step 254 of the device recommendation 
algorithms 112. Step 254 filters the recommendations XML file 250 received in message 515*. The filtering identifies 
new or significant information in the recommendations XML file 250. This can be accomplished by comparing the 
recommendati ons XML file 250 with the past recommendations XML files 227 in the service history log 110. The 
process then flows to step 256 which displays the filtered recommendations to the user on the browser 1 02 shown in 

35 Fig. 3H. An XSL stylesheet can be used to display the desired content of the recommendations XML file 250 in the 
browser 102. Fig. 3H shows the result of a first filtering criterion of "FILTER = NO AGE RESTRICTION". The one of 
the two recommendations displayed in Fig. 3H has the characterization "Ages: Adult" (Fig. 4E). Alternately, if the filtering 
criterion were "FILTER = FAMILY ORIENTED" as provided in Fig. 31, then only one of two potential recommendations 
is displayed, the displayed recommendation having the characterization "Ages: All Ages " (Fig. 4E). In the alternative 

40 to step 256, the recommendation process or recommended services may be transparent to the user of the wireless 
device 100, as shown by reference numeral 257. 

[0101] The process then flows to step 258 which optionally transfers the recommendations 250 to the application 
programs 106 for further processing. This same sequence of steps is automatically performed by the wireless device 
100 and the network server 140 in response to the wireless device 100 automatically transmitting mes sages with a 

45 unique op code designating that the message is an automatically transmitted message. 

[0102] The process then continues to step 260 in which the wireless device receives the user's voice command and 
identifies the service (from the recommended servic es) with a voice short-cut matching the user's voice command. At 
step 262, the wireless device accesses the identified service. For example, the user may say the voice command "Arts" 
or any phonetic equivalent thereof to initiate access to the service Ar tsclub.com. As shown in Fig. 4E, the voice short 

so for the recommended services may be received from the server 140 as voice tags in an XML file. 

[01 03] The recommendations XML file 250 providing two digital service recommendations for galleries, is shown as 
the example XML file of TABLE D, as follows: 



55 



21 



EP 1 333 650 A2 



TABLE D- Example of an XML File Specifying New Recommendations 
<?XML VERSIONS 1 .0 n ?> 

<DOCTYPE RECOMMENDATION SJDBJECT "xml^directory \object dtd">. 
<RECOMMEND ATION S_OBJECT> 

<DESCRIPTION>New Recommendations</DESCRIPT ION> 

<RECOMMEND ATION > 
<NAME> 

<HOSTNAME>Artschib.com</HOSTNAME> 
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<SERVlCENAME>[service name or extension]</SERVICENAME> 

<VOICETAG>Arts<7VOICETAG> 
</NAME> 
<LOCATION> 

<ADDRESS>789 Eastern Blvd</ADDRESS> 

<AREA>Southside </AREA> 

<LAT>(Lat)</LAT> 

<LON>Lon</LON> 
</LOCATION> 
<AGES>Adult</AGES> 
<TIMES>10:00 - 17:0(X/riMES> 
<ADMISSION>$5.00 adult</ADMISSION> 
<DRESS>casual dress</DRESS> 
</RECOMMENDATION> 
<RECOMMENDAT10N> 
<NAME> 

<HOSTN AME>Wayoutart com</HO STNAME> 
<SERVICENAME>[service name or extension]</SERVICENAME> 

<VOICETAG>Way Out</VOICETAG> 

</NAME> 

<LOCATION> 

<ADDRESS>248 Circle Rd</ADDRESS> 
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<AREA>Mountains </AREA^ 
s <LAT>(Lat)</LAT> 

<LON>Lon</LON> 
</LOCATION> 

10 

<AGES>AU Ages</AGES> 
<TIMES>10:00 - 17KHX/T1MES> 
<ADMISSION>$5.00 adult/$2.50 chil<K/ADMISSION> 
<DRESS>casual dress</DRESS> 
20 </RECOMMENDATION> 

</RECOMMENDAT10NS_OBJECT> 

25 [01 04] An abbreviated example of a corresponding document type definition (DTD) that specifies the allowed order, 
structure, and meaning of the tags for a new recommendation XML file 250, is shown in the following TABLE E. This 
DTD is part of a file named "objectdtd" stored in the local filesystem directory named ^mLdirectory 0 in both the wireless 
device 1 00 and the network server 1 40. It illustrates, for example, that new RECOMM ENDATIONS sent to the wireless 
device 100 must include NAME and LOCATION of the service, but it does not include the complete CONTEXT. The 

30 NAME must include HOSTNAME, SERVICENAME, VOICETAG; and the LOCATION must include ADDRESS, AREA, 
LAT, LON. The DTD can provide for optional data in the XML file, as well, by including other elements, such as "AD- 
MISSION^ and designating them with an asterisk so that they are not necessarily required in each XML file. The 
same XML tag parser in both the device recommendation algorithms 1 1 2 of the wireless device 1 00 and in the server 
recommendation algorithms 1 66 of the network server 1 40, can search the XML file for optional XML tag strings, such 

35 as the beginning tag "ADMISSION;*" and the ending tag "</ADMISSION>", and if they are found, the XML tag parser 
gets the data located between the tags and passes it as "admission data" to program subroutines that operate on 
admission data. 

TABLE E - 

40 Abbreviated Exa mple of a DTD for New Recommendations 

<!ELEMENT RECOMM ENDATIONS_OBJECT ( DESCRIPTION, RECOMMENDATION )> 

<! ELEMENT RECOMMENDATION (NAME, LOCATION, ADMISSION*)> 

<!ELEMENT NAME (HOSTNAME, SERVICENAME, VOICETAG)> 

<!ELEMENT LOCATION (ADDRESS, AREA, LAT, LON)> 
45 <!ELEMENT ADMISSION (#PCDATA)> 

[0105] To enable the wireless device 1 00 to read the XML recommendations file 250 of TABLE D, a DOM tree -based 
parser in the device 100 reads in the DTD of TABLE E and the XML file 250 received from the network server 140. 

50 The DOM tree-based parser converts the XML file 250 into a hierarchical tree data structure enabling the data for each 
element to be accessible to the application programs 106 and recommendation algorithms 112. 
[0106] This process also works in reverse in the network server 140 and enables the network server to construct the 
XML recommendations file 250. The DOM tree -based parser can read in the DTD of TABLE E and create the hierar- 
chical tree data structure that serves as a template for the recommendation algorithm 1 6 6 in server 1 40. The recom- 

55 mendation algorithm 1 66 can then fill the nodes of the tree with recommendation data, such as ADDRESS data, AREA 
data, LAT data, and LO N data. The DOM tree -based parser uses this newly created tree of data to create a correspond 
ing XML recommendations file 250 of TABLE D, that conforms to the DTD of TABLE E. The recommendation algorithm 
1 66 and the DOM tree -based parser, in effect, work together as a document generator. The Document Object Model 
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(DOM) defines the characteristics of the XML file hierarchical tree data structure and an ^^J^^^J 
nterface (API) for manipulating it. A description of DOM is provided on the web site http-y/www.w3.orgn-R/DOM -Level- 
2-Core/ For additional information on the Document Object Model and the XML file hierarchical tree data structure, 
see the book by Elliotte Harold, et al, entitled XML In A Nutshell , O'Reilly & Associates, 2001 . 
[0107] In an alternate embodiment, the wireless device uses the SAX event -driven parser and the network server 
140 uses the DOM tree -based parser. This arrangement confers the advantageof requiring a smaller memory allocation 
for the SAX parser in the wireless device 1 00 and yet it provides the capability of the DOM parser to construct the XML 
recommendations files 250 in the network server 140. n . m „. K 

[01081 In another alternate embodiment, Extensible Hypertext Markup Language (XHTML) can be used to display 
if desired in the wireless device 1 00 the recommendations and/or voice tags of files 250 in step 256 which are receded 
from the network server 140. XHTML is a hybrid between HTML and XML specifically designed for network device 
displays A subset of XHTML is XHTML Basic, which defines a document type that is rich enough to be used for content 
authoring and precis e document layout, yet can be shared with wireless mobile devices 1 00 with small screens, such 
as PDAs and cell phones. XHTML Basic is the mobile adaptation of XHTML, and includes everything in XHTML except 
those capabilities, such as frames, that are not appropriate for devices with small screens. XHTML Basic is an XML- 
based standard, which allows the automatic parsing and transcoding of contentthrough the use of Extensible Stylesheet 
Language Transformations (XSLT). part of the XSL style sheet language for XML. XSLT provides a language for trans- 
forming XML documents into other XML documents. Using XSLT. a system can automatically transform the same XML 
content into multiple markup languages depending on the browser 102. Through such transformations, content can 
be created for one type device and automatically transformed to appear on another type device. For example^ 
network server 140 can create its recommendations once in XML and use XSLT to dynamically convert it to XHTML 
Basic and HTML for presentation on mobile wireless devices 100. 

[01091 XHTML Basic can used with cascading style sheets (CSS) to describe how documents are presented on 
screen in the browser 1 02. Through the use of CSS, document authors can control the presentation of documents wrth 
out sacrificing device independence. The use of well-known standard HTML tags avoids storing multiple versions of 
content. The network server 140 does not need to provide for extra overhead for transcoding required to prepare 
content for an array of different markup languages. CSS enables a document author to specify the presentation of an 
application once for each type of device, by means of a corresponding style sheet. If the Presentation needs to be 
changed* any time, the change is made onceinthestylesheetandthemodification is dynamically reflectedthroughout 
all the pages in the network server 1 40. CSS separates the content of the document from the presentation. The allows 
creatingbrowser-specfficversionsofthesamecom^ 

type. Then, when a user requests a page at the wireless device 100, the network server 140 server .dentrfies the 
requesting device and returns the content with a link to the appropriate style sheeL The style sheet » downloaded 
once and cached by the browser 1 02 for use with subsequent pages, which speeds the rendering of all pages received 
from the network server 1 40. CSS enables every aspect of the appearance of the document, such as positioning, font 
s text attributes, borders, margin alignment, and flow, to be defined in the style sheet. A change to any aspect of the 
documents appearance needs to be made only once. CSS also gives carriers greater control over the look and feel 
of the services they provide through their wireless portal. The operator can use XHTML Basic to define a default style 
sheet for all devices it supports, which will ensure a basic look and feel consistent for all devices 1 00. 
[01 101 Fig 4F is a flow diagram of the process in the network server 1 40 to respond to the recommendation request 
message 521 from the device 100. Fig. 4F differs from Fig. 4D by showing how to find database recommendations 
that are similar to the past services used by the wireless device 100, instead of be ing similar to the past recommen- 
dations received by the device. The network server 1 40 of Fig. 4F includes the server op code parser 21 6 that interprets 
the op code value "RQ_REC_4- as indicating that the message is a recommendation request message i 521 . In re- 
sponse the server op code parser 216 invokes step 240 of the server recommendation algorithms 166. Step 240 
receives the metadata vector 138 from the message 521 and accesses recommendations from the database 192 
corresponding to the current context . The process then flows to step 243 which searches through the accessed rec- 
ommendations obtained from the database to find those similar to the past services used XML file 235 input from he 
message 521 . The process then flows to step 244 which sorts t he similar recommendations in accordance with the 
user's preferences 231. also received in the message 521. The process then flows to step 246 which updates usage 
statistics and stores them in a database. The process then flows to step 248 which assemble s the recommendation 
response message 521' and transmits it back to the wireless device 100. The recommendation response message 
52V includes the network address of the wireless device 100, the op code -REC_3' that designates the message as 
a recommendation response message, and the operands. The operands include the recommendations XML file 250. 
which preferably include the service address of the recommended services (e.g., host name, service name) and one 
or more associated voice tags. ,„™ 
[01111 Fig. 4G is s imilarto the flow diagram of Fig. 4E, of the process in the wireless device 100 to filter the recom- 
mendations received in the recommendation response message and output, audibly or visually, the filtered recommen- 
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dations on the device's browser. The proce ss displays the filtered recommendations to the user on the browser 102 
shown in Fig 31. This same sequence of steps is automatically performed by the wireless device 100 and the network 
server 140 in response to the wireless device 100 automatically tra nsmitting messages with a unique op code desig- 
nating that the message is an automatically transmitted message. „ 
[01 121 Another example is when the user requests a location -based recommendation with the device 1 00. As dis- 
cussed above, Fig. 4 shows the service his tory log 11 0 has accumulated data on past services used by the user of 
the device 100 and the contexts of those past services. The recommendation algorithms 112 automatically filters the 
service history log 110 and selects past services used by the user of the device 100 and the contexts of those past 
services, treating them as context-activity pairs. It is not necessary that these pairs of selected past services used and 
past contexts be related to the current context of the device 100. Two examples of t hese past pairs of selected past 
services used and past contexts are numbered [1 0] and [11] as follows: 

[10] °location=xyz1 ; service=www.newsservice.com/..7news.wml" l and 
[11] "location=xyz2; scrvicc=www.stockquotes.com/. Jquotcs.wml". 

[01131 The device 100 then sends these two automatically selected past pairs to the network server 1 40. The rec- 
ommendation algorithms 112 filter out any reference to the user's ID before sending the pairs to the server Then, 
device 1 00 then sends the current context "location=xyz3" to the network server 140. The current context xyz3 can 
represent the airport, for example. When the network server 140 receives the two example past pairs of selected past 
services used and past contexts, it stores them in its database 192. Pa st pairs such as these can be accumulated 
from many users as recommendation resource in the database 192 for use by many other users. Examples of nine 
other past pairs previously accumulated in database 1 92 from other users are: 

[1] "Iocation=xyz3; service=www.air1ines1.com/..7timetables.wmr i 
[2] B location=xyz3; service=www. airtines2.com/.. J timetables.wml", 
[3] B location=xyz3; service=www. airiines3.com/.. J timetables.wml", 
[4] B location=xyz3; service=www.weatheronline.com/..7weather.wmr, 
[5] B iocation=xyz4; service=www horoscope 1. com/.. ./stars.wmr, 
[6] °location=xyz4; service=www. horoscope2.com/.. Vstars.wml", 
[7] "location=xyz5; service=www.emailservicel.com/..7mail.wmr, 
[8] B location=xyz5; service=www. emailservice2.com/..7mail.wml", an d 
[9] "location=xyz5; service=www emailservice3.com/.. ymail.wml", 

[0114] The network server 140 compares the current context "Iocation=xyz3" the past contexts of past pairs previ- 
ously accumulated in database 192. There are four matches: 

[1] B location=xyz3; service=www.air1inesl.com/..ytimetables.wmr, 
[2] B location=xyz3; service=www. airlines2.com/.. J timetables.wml", 
[3] B location=xyz3; service=www. airlines. 3com/.. J timetables.wml", and 
[4] B location=xyz3; service=www. weatheronline.com/.. Tweather.wml °. 

[0115] The network server 140 sends a list of the four past services used (by others) taken from the list of the four 
matches, as four recommendations to the user's device 100. The four recommendations are: 

[1] service=www.airlines1 .conV..Vtimetables.wmr, 
[2] service=www. airiines2.com/.. J timetables.wml", 
[3] service=www air1ines.3com/..7 timetables.wml", and 
[4] service=www.weatheronline.com/..yweather.wmi B . 

[01 1 6] The recommendation algorithms 1 1 2 in the user's device can filter these four recommendations received from 
the server if desired. The filtered recommendations are then output, audibly or visually, to the user and one or more 
of these recommendations can be selected by voice command or other input mechanism. Alternately, the recommen- 
dations may be transparent to the user of the wireless device 100. The user's selected recommendations and the 
current context "location=xyz3 B are then stored in the service history log 1 1 0. For example, if the user selects by voice 
command or other user input m eans: 

[2] service=www.air1ines2.com/..7timetables.wml B , 

then this recommendation and the current context "location=xyz3" are stored in the service history log 110. 
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r0117l While the above discusses an example of location -based recommendations, recommendations may similarly 
be determined based on various user filter criterion which infer a context. As discussed herein, these factors may 
include temporal variables (e.g., time, date, day of the week, daytJme/nightime, etc.), device settings (e.g.. profile of 
the wireless device or the user), and so forth. 

F0118] Rg 4H is a flow diagram of an exemplary process in the wireless device 100 to determine recommended 

services via recommendation algorithms 112, and to enable access to such services via voice short -out. The process 

commences at step 264 in which a voice or key command is received to initiate local recommendat.cn process, such 

as menu item [8] LOCAL RECOMMENDATION of Rg. 3A. Recommendation processing may also be initiated by other 

manual control by the user, or automatically upon various triggering events (e.g.. location, temporal vanables, penod- 

icallv specific user activity such as accessing a particular Internet site or service, and so forth). 

T01 1 1 91 The wireless device 1 00 then accesses recommendations from d atabase corresponding to a current context 

at step 266, and identifies database recommenda^ ^ 

device 1 00 sorts similar database recommendations by user's service preferences. 

[0120] Thereafter, at step 272, the wireless device 100 audibly or visibly outputs the service recommendations to 
the user. The process continues at step 274 with the wireless device 100 receiving a voice command (or other user 
inputcommand). In the event of a votee in put, the wireless device 1 00 performs voice recognition on thevo.ce command 
toidentifytheservice (from thesubset of recommendedservices) with a voice short -cut match,ng me voice «>mmand 
at step 274. At step 276. the wireless device 1 00 accesses th e identified service. Further browsing of the service or 
control of the device via mufti -modal user input can be processed at step 278. 

[01 21] Rg 41 is a flow diagram of an exemplary process in the wireless device 1 00 to resolve multiple service match- 
ng issu es either by priority or by allowing the user to select from the plurality of matched services. The Process 
commences at step 280 in which the wireless device 100 obtains a recommendation of serv.ces, whichmayalso include 
prioritizing therecommended services. The priority of a service may bebased on " um ^ ,a f°f • suchM ^'" 9 r 
to a weight given to the services based on a particular context which may correlate to the level of usage in a partcular 
context. For example, in the "work" context (e .g., the user is in the Office), the user typically utiles ^mmended 
servfce-1 more than recommended service-2sothat S ervice-1 isprovidedahigherprior^thanserv^ 
[01221 At step 282, the wireless device 1 00 receives a votee command from the user. At step 284, the wireless device 
284 compares the voice command to the voice short -cuts of the recommended services. At step 286, the wireless 
device determines whether there are more than one sen/ice matches or only one sen/ice match If there is on* one 
service match, then that service is accessed. If there is no match or the matching probability of all the voice short -cuts 
are below are threshold, then the voice command e ignored and the wireless device 1 00 is reset to recede the vo ice 
command again. The threshold may be adjusted to adjust the sensitivity of the decoding, as desired 
[0123] Otherwise, if a plurality of services are matched, then in one alternate the process proceeds to step 288 in 
whteh a service is selected from the m atoning services according to the priority of the services. For examp to ,\he 
matching service with the highest priority is selected. At step 294, the wireless device 100 accesses the selected 
service 

[0124]' Altematively.theprocessmayproceed to step 290inwhich an indication* the ma ^' n 9 sen ^ s ^°"J^ 
tothe user. The indication may take the formofthe voice short- cuts forthe matching services. At step 292, the wireless 
device 100 receives and processes the user selection (e.g., by voice/ke y command), and at step 294 accesses the 
selected service 

[0125] Turning now to Fig. 5, a functional block diagram is shown of the wireless device 100, «"h its various com- 
ponents and programs. The 'memory 202 of the wireless devica 100 is connected by means o the bus 204 to the keypad 
104 the radio 206, the speaker 107, the microphone 103, the sensor interface 208, the central processor 210 and the 
display 21 2 which displays the browser 102. The input and output devices may be physically connected to ^thercom- 
ponents of the wireless device 100, such as the processor across the bus 204. or at least one of the input device (e. 
g.. the voice input device) and the output device (e.g., the display device) may interact with the processor ot otor 
components of the wireless device 100 across a wireless short-range link. For example, the input device andthe output 
device may be different ones. . ... 

[0126] The memory 202 stores the context -activity pair and service history log 110, which « shown in greater deta. 
n a fit example in Fig. 4. The memory 202 also stores the current context state 111 which includes . > ^nptton of 
the environment of the wireless device 1 00 at the present time. As will be discussed further below, the charactenza ion 
of the environment of the wireless device 100. may involve one or more variables (e.g location, ^P 0 ^"^' 
user and device profile, sensory input(s). etc.) and may include generation of the metadata ^ 138 " h ^' u ^ 
information relating to the sensor signals in putfrom the sensors at the current time. Also i '" duded '"^^^ 
are recommendation algorithms 112. voice recognition engine 113, voice response unit 118, voice tag generator 119 
and WAP client program 1 08, some of which will be discussed f urthe r below. Memory 202 also stores other information, 
such as the user or device profiles. 
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CONTEXT SENSITIVE WEB SERVICES 

[0127] In addition or alternative to the context inference techniques (such as based simply on temporal variables, 
position variables, dev ice or user profile, etc.) employed in the recommendation operation, the wireless device 100 
may be configured with a more complex context determination scheme, referred herein as sensitive web services 
feature, to enable a mobile phone or wireless PDA to use context inference techniques to sense the user's environment 
and in response, to provide recommendations to the user that is appropriate to the user's environment and that can 
be accessed by the user's voice command or other form of user input. In the distributed network embodiment, the 
feature offloads some of the computationally intensive computing necessary in context inference techniques, recom- 
mendation techniques and/or voice recognition techniques from the mobile user's wireless device to a serve r and to 
web sites on the Internet. 

[0128] The context sensitive web services feature may also maintain a personal profile of the mobile user's personal 
preferences in an online server or web site. The mobile user is provided with the ability to control acce ss by application 
programs in the wireless device, to the user's private data. The context sensitive web services feature provide the 
is mobile user with the ability to control any access to the user's profile by the online server or web site, particularly where 
processing is offloaded from the wireless device to other network elements. 

[0129] The mobile user's wireless device is equipped with a context inference engine for providing an awareness of 
the mobile user's context to application programs, including third party applications. Since the processing power and 
storage capacity is limited in typical wireless devices, the computational load and storage requirements of the context 

20 inference engine are distributed to a context inference server capable of processin g the context data. This equally 
holds true in various embodiments in which other processing tasks, such as service recommendation and voice rec- 
ognition to enable voice -based access to recommended services, are otfloaded to network elements. 
[0130] The feature also enables the mobile user to control which application programs in the wireless device are 
granted access to the user's private context information. A privacy control block in the wireless device grants or revokes 

25 access by application programs to the p rivate context information, based on the mobile user's preferences stored in 
a privacy profile. The same privacy control and privacy profile is extended to the context inference server, thereby 
enabling the extension of the user's privacy control to any w eb server connected to the context inference server. The 
feature thus enables building an infrastructure for context sensitive applications and services within the wireless device 
and the server, while providing to the mobile user control over the privacy user's context information. 

30 [0131] The Recommendation Web Services menu displayed by the browser 1 02 in Fig. 3A is rendered by the WAP 
client program under the control of the application programs 106, which are shown in Fig. 5. 
[01 32] Fig. 5 is a functional block di agram of the wireless device 1 00, showing its various components and programs. 
The wireless device 100 has context sensitive applications A, B, X, and Y, either downloaded, or in firmware. The 
wireless device 100 does not need to utilize external functionality in the network forthe initial sampling and digitization 

35 of the sensor inputs. The sampled and digitized values of the sensor inputs are POSITIONING METADATA 122', 
TOUCH METADATA 124' AUDIO METADATA 125', COMPASS METADATA 126', AMBIENT LIGHT METADATA 128', 
AMBIENT TEMPERATURE METADATA 1 32', and THREE-AXIS ACCELERATION METADATA 134'. The sampled and 
digitized values of the sensor inputs are loaded into a metadata vector 138. 

[0133] Fig. 5 shows the memory 202 of the wireless device 100, connected by the bus 204 to the keypad 104, the 
40 radio 206, the speaker 1 07, the microphone 1 03, the sensor interface 208, the centralprocessor (CPU) 21 0, and the 
display 212. The memory 202 stores programs which are sequences of executable instructions which, when execut 
ed by the processor 210, carry out the methods of the features discussed herein. The memory 202 stores the WAP 
client program 1 08, the context inference engine 1 36, the privacy control 1 50, the privacy profile 1 52, the context aware 
AP1 154, the motion/ges ture API 156, the location API 158, and other APIs 162. The context inference engine 136 
45 processes the metadata vector 138 to produce the current context. Application programs 106 stored in the memory 
202 include the application programs A and B which are part of the software system SS1 , and the application programs 
X and Y which are contained in the execution environment "Exec. Env." 

[01 34] If sufficient computational power and storage capacity are available in the wireless device 1 00, further process- 
ing of the metadata vector 1 38 can take place in the context inference engine 1 36, toward the objective of producing 

so the result of an inferred current context. However, if at some point in the computation, the context inference engine 
136 needs the processing power or storage capacity available at the network server 140, the metadata vector 138 is 
sent from the wireless device 100 to the context inference engine 142 in the network server 140 of Fig. 6. The context 
inference engine 142 in the network server 140 can perform the required processing on the metadata vector 138 and 
then return it to the context inference engine 136 in the wireless device 100 for completion of the an inferred current 

ss context result. Alternately, the context inference engine 142 in the network server 140 can complete the required 
processing and then return the resultant inferred current context to the wireless device 100. 
[01 35] Fig. 5 shows the architecture of a wireless device with support for context awareness. The context awareness 
is bu ilt on top of sensory information received from various types of sensors physically located in the handset shown 



28 



EP 1 333 650 A2 



in Fig. 1. The sensors shown include POSITIONING SENSOR 122, TOUCH SENSOR 124, AUDIO SENSOR 125, 
COMPASS SENSOR 1 26, AMBIENT LIGHT SENSOR 1 28, AMBIENTTEMPERATURE S ENSOR 1 32, and THREE-AX- 
IS ACCELERATION SENSOR 134. The sensors can also be located in accessory-like phone covers or in a wireless 
accessory such as a Bluetooth enabled device. The sensors may also be located in the environment such as in the 
s user's rooms or vehicles. Also, the time duration of use of a phone and other available information can be used along 
with sensor data in context awareness services. Such other information may include other user -related filter criteria, 
such as temporal variables, the device or user profile, and so forth. 

[0136] Fig. 5 shows sensor data received from the sensors 122, 124, 125, 126, 128, 132, and 134 is processed by 
Context Inference Engine 136 which then feeds the data through various APIs 154, 156, 158, and 162 to application 

10 programs A, B, X, and Y. The application programs may register themselves at the Application Programming Interface 
154 to receive current context or changes in the context. This enables context sensitivity in the application pro grams. 
[0137] Fig. 5 shows "native" application programs A and B which are executed in a first software system SS1 of the 
wireless device 1 00. The term "Software System" is used here for any environment with execution capability. This first 
software system may be proprietary or based on a commercially available real -time operating system, such as NOS, 

15 ISA, EPOC, JAVA, or WAP. Third party application programs X and are executed within an execution environment. 
This execution environment may limit the system cap abilities available for the application programs, such as access 
to APIs (fixed, not dynamic behavior). 

[0138] Fig. 5 shows the mobile user's privacy control feature. The privacy control feature enables the user to desig- 
nate which application programs are gra nted access to the context awareness APIs 154 to utilize the current context 

20 information produced by the context inference engine 136. All requests or registrations by application programs A, B, 
X, and Y to have access to the Context Inference Engine 136, must first go through the Privacy Control block 150. 
Privacy Control block 150 uses the user's security data check stored in the Privacy Profile 152 to grant access rights 
to the requesting application programs. The user controls the granting of access rights by means of the user's security 
data input by the user through the user interface. The user's security data includes permissions list 155, Public Key 

25 Infrastructure (PKI) certificates 1 57, PKI trusted authority trust list 1 59, and flags set by the user for those application 
programs that have been authenticated by the PKI procedures, data set 161. The user can, if desired, be provided 
with the capability of updating the user's security data. Access might be granted to an application program based o n 
its digital signature, which is a part of the system applications, or other means known in the art. It is also possible to 
provide a separate system - wide Privacy User Interface to the privacy control 150, which can be employed by the 

30 mobile user to set the privacy policies and to alert the mobile user that an application program is attempting to register 
to receive the user's private context awareness information. The privacy control 150 and Privacy Profile 152 enable 
the mobile user to grant, deny, or r evoke access, to grant access for a limited time, or to require an application program 
to always request registration before the user grants access. 

[0139] In Fig. 5, the Context Inference Engine 136 in the wireless device 100 makes inferences from all the senso 
35 r inputs based on where the wireless device is located by the mobile user. For instance the inferred current context of 
the device 1 00 may be "IN THE USER'S POCKET, when a certain set of sensors input a specific combination of signals 
having a specific value range. As an example, the resulting inference of the current context by the Context Interference 
Engine 136 could be expressed in XML language format as follows: 

40 <Context Inference Engine in Device> 

[0140] 

<device placement pocket </ device placement 

45 

<User Interface state> sleep mode </User Interface state> 
<device location> in elevator 5 building 1 floor 2<J device location> 
50 <API active actions> meeting starting on floor 3 room 322 </API active actions> 
</Context Inference Engine in Device > 

[0141] The Context Inference Engine 1 36 in the wireless device 1 00 can perform the context inference process with 
55 any of several methods. Different input information from the sensors can be weighted according to their relative value 
of importance appropriate for each environment condition or situation to be analyzed. Each sensor has it's own weight 
value. Alternatively, the weight values for each sensor for each environment condition can be learned from training 
sessions using, for example artificial neural networks (AN Ns), self-organizing maps (SOMs), decision trees, fuzzy rule 
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-based systems, or model -based systems such as Hidden Markov Modeling (HMM). Combinations of two or more of 
the alternate methods can be used, depending on the application. 

[01 42] The Context Inferenc e Engine 136 can continuously adapt its weights through adaptive and continuous learn- 
ing methods, where the user teaches the wireless device 100 new environment conditions and names them. Hidden 

5 Markov Modeling (HMM) can be used, for example, to implement an adaptive and continuous learning method for the 
Context Inference Engine 136. Alternately, the wireless device 100 can be programmed to spontaneously recognize 
a changed scene by comparing it with known scenes. The user can teach the wireless device new environmental 
conditions and name them, using the adaptive and automatic learning capability of neural networks. Adaptive and 
continuous learning methods are computationally intensive and are appropriate candidates to place on the network 

10 server 140, w hich assists the wireless device 100, as discussed below. 

[01 43] The field of context inference has applied the principles of automated pattern recognition to processing diverse 
types sensor inputs. Speech recognition has been applied to processing speech sign als and handwriting recognition 
has been applied to processing hand force and accelerometer signals. In the field of robotics, image recognition has 
been applied to processing digitized still and motion images, mechanical location recognition has been app lied to 

15 processing laser and sonar range finder signals, and mechanical motion recognition to has been applied to processing 
inertia!, acceleration, and heading signals. In the field of prosthetic devices, touch recognition has been applied to 
processing tactile sensor signals. In the field of medicine, automated diagnostic programs recognize various patholo- 
gies by processing bioelectric field signals, as well as the more traditional pulse, respiration rate, and body temperature 
signals. These diverse se nsor signal recognition processes have the common feature that an initial training stage is 

20 conducted where sampled signals are equated with a statistical model for those signals. 

[0144] The principles of automated pattern recognition for these diverse sensor inputs are exemplified by the tech- 
niques for recognizing speech patterns. A common technique used in speech recognition is Hidden Markov Modeling 
(HMM). The term "Hidden" refers to the probabilistic and not directly observable events which underlie a speech signal. 
HMM speech recognition systems typically use realizations of phonemes which are statistical models of phonetic seg- 

25 ments having parameters that are estimated from a set of training examples. Models of words are made by chaining 
or linking ap propriate statistical models of phonetic segments. The statistical models serve as standards which are to 
be matched with the unknown voice signals to be recognized. 

[0145] Recognition of unknown voice signals requires sampling and digitizing the speaker's spoken phonemes. 
These digitized phonemes are then processed into data suitable for analysis by a speech coder. The data is then 
30 compared with the standard statistical models of phonemes. The most likely matches are then the inferred speech 
recognition re suit. 

[0146] Recognition consists of finding the most likely path through the set of word models for the input speech signal. 
HMM speech -dependent recognition decoding systems first need to be trained through an iterative process. The 
system must be exposed t o training examples or words of a particular speaker's voice. A training word is analyzed to 
35 generate a framed sequence of acoustic parameters or statistical models. A valid or "good" recognition occurs when 
the most likely path through the set of word mo dels for the training word results in recognizing the correct training word. 
[0147] Some useful references discussing the principles of Hidden Markov Models are: 

Rabiner, L. R., "A tutorial on hidden Markov models and selected applications in speech recognition", Proceedings 
40 of the IEEE , volume 77, number 2, 1 989, pages 257 -286. 

Rabiner, L. R. and Juang, B. H., "An introduction to hidden Markov models", IEEE ASSP Magazine , January 1 986, 
pages 4-15. 

[0148] Fraser, Andrew M. and Dimitriadis, Alexis, "Forecasting Proba bility Densities by Using Hidden Markov Models 
45 with Mixed States", Time Series Prediction: Forecasting the Future and Understanding the Past , Addison-Wesley, 
editor Weigend, Andreas S. and Gershenfeld, Neil A., 1994. 

[0149] Chamiak, Eugene, Statistical Language Learning , MIT Press, Cambridge, Massachusetts, 1993. 

[0150] To illustrate how Hidden Markov Modeling (HMM) can be extended beyond speech recognition, an example 

is given here for touch recognition. In the training stage for touch recognition, tactile sensor signals are input from 

so touching a tactile transducer to a rough texture, such as for example sandpaper. The tactile sensor signals are trans- 
formed into a statistical model of the input signal. The statistical model is stored as a standard in a computer memory 
under the handle "roughjexture". To expand the range of sensor signals that are included in the model for 
"roughjexture", several training sessions can be conducted, each with a different direction or pressure for touching 
the sandpaper, resulti ng in several different samples of the statistical model. The set of samples of the statistical model 

55 are stored as a standard under the handle "roughjexture". Other training sessions are conducted with a smooth 
texture, such as glass. The tactile sens or signals input from touching the tactile transducer to the smooth texture are 
transformed into a statistical model of the input signal and stored as a standard under the handle "smooth Jextu re". 
Later, in the recognition mode, an unknown object is touch ed by the tactile transducer resulting in a sample tactile 
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sensor signal. Recognition of unknown touch signals requires sampling and digitizing the touch transducer's signals. 
These digitized sensor signals are then processed into metadata. The metadata is then compared with the standard 
statistical models of "roughjexture" and "smoothjexture". The most likely match is then the inferred touch recognition 

raiSIl Combinations of two or more types of sensors can have their signals combined into an input metadata vector 
that characterizes a composite sampling event. The composite sampling event can be recognized using the principles 
of Hidden Markov Modeling (HMM). An example composite sampling event can be the state of the health and fatigue 
of the us er of a wireless device 1 00. For example, a wireless device 1 00 can be equipped with a tactile transducer 
which outputs tactile sensor signals in response to the hand force and pulse rate of the user who is gripping the wireless 
device 100 The wireless device 100 can be equipped with a temperature sensor which outputs body temperature 
signals in response to the user gripping the wireless device 100. Hidden Markov Modeling (HMM) can be used to 
recognize a force/temperature input metadata vector that cha racterizes the combination of the hand force and the 
temperature sensor signals resulting from a sampling event. A composite sampling event in this example can have an 
extended duration so that the force sensor can transduce the pulse rate of the user over a period of time. 
[01 52] In the training stage, the tactile sensor signals and the force sensor signals are output while the user is in a 
condition of good health and resting normally. The tactile sensor signals and the force sensor signals are combined 
int o a forceAemperature input metadata vector which is transformed into a statistical model of the input signals. The 
statistical model is stored as a standard in the computer memory of the wireless device 100 under the handle 
"good_health_ resting_normally ". Other training sessions are conducted with the user in different states of health and 
fatigue For example, the user may be training the wireless device 100 while working late at night at the office. The 
tactile sensor signals and the force sensor signals resulting from holding the wireless device 100, are combined into 
a forceAemperature input metadata vector for the user in the condition of being in good health but fatigued. The force/ 
temperature input metadata vector is transformed into a statist ical model of the input signals and stored as a standard 
under the handle "good_health_ fatigued". 

[01 531 Later, in the recognition mode, as the user holds the wireless device 1 00, the tactile sensor signals and the 
force sensor signals are sampled. The Heal th/Fatigue_State recognition consists of sampling and digitizing the touch 
transducer's signals. These digitized sensor signals are then processed into a metadata vector. The metadata vector 
is then compared with the standard statistical models of handle "good_health_ restingjiormally" and "good_health_ 
fatigued". The most likely match is then the inferred touch recognition result. 

[0154] In accordance with the feature, this recognition result can be used by the recommendation engine in the 
wireless device 1 00 or the server 140, to determine recommended services from a plurality of services. For example, 
the recommendation engine can process the recognition result, and in response, identify a subset of recommended 
services according to the health state or other inferred state of the user. One problem with automatic recognition pro- 
grams is that they are either relatively large or they call databases that are relatively large in comparison to the memory 
capacity of the wireless device 1 00. . 
[0155] Returning to Fig. 1 , the relationship is shown between the network server 140, the Universal Descnption, 
Discovery and Integration (UDDI) registry 170, and a plurality of web site servers 1 60. UDDI is a defacto standard for 
an Internet -based registry. The UDDI registry 170 enables the network server 140 to discover new web sites for 
services and businesses on the Internet. Once such services and businesses are identified by the UDDI registry 170 
to the network server 140, then the server 140 must apply the mobile user's cached privacy profile 144 in Fig. 6, in 
order to prevent unauthorized access of the user's private data by application programs on the newly discovered web 
sites. 

[01 56] Voice tag registry 1 72, in a similar fashion, may enable discovery of voice tags, or generally voice short-cuts, 
for various digital services on the Internet. 

[0157] Fig 5A is an exemplary network process flow diagram of the interaction of the wireless device 1 00 and network 
server 140 in which voice recognition processing of the user's voice command to select a service to access from the 
recommended services is performed by the network server 1 40. At step 360. the wireless device 1 00 receives a voice 
command from the user. At step 362, the voice command data is sent to the network server 140 whic h performs voice 
recognition processing on the voice data to identify a matching service from the recommend services. At this point 
the network server 140, in step 366, can send an indication identifying the matched service to the wireless device 1 00 
which then accesses the matched service at step 368. Alternatively, the network server 140 can establish a connection 
between the wireless device 100 and the service provider of the matched service. 

[01 58] Fig 6 is a functional block diagram of the network serve r 1 40, showing the memory 402 storing the application 
services software programs needed to perform the operations of the feature. The memory is connected by the bus 404 
to the cache 144, user database 146, TCP/IP network adapter 406, and central processor410. The memory 402 stores 
programs which are sequences of executable instructions which, when executed by the processor 410, cany out the 
methods of the feature. 

[0159] In Fig. 6, the functional components of an exemplary network server 140 are shown arranged as an object 
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model. The object model groups the object oriented software programs into components that perform the major func- 
tions and applications in network server 1 40. The object model for memory 402 of network server 140 employs a three 
-tier architecture that includes presentation tier 415, infrastructure objects partition 422, and business logic tier 414. 
The object model further divides business logic tier 414 into two partitions, application objects partition 422 and data 
5 objects partition 426. 

[0160] Presentation tier 415 retains the programs that manage the device interfaces to network server 140. In Rg. 
6, presentation tier 415 Includes network interface 420. A suitable implementation of presentation tier 415 may use 
Java sen/lets to interact with WAP protocol gateway 1 20 via th e hypertext transfer protocol ("HTTP") . The Java servlets 
ran within a request/response server that manages the exchange of messages between WAP protocol gateway 120 

io and network server 140. A Java servlet is a Java progra m that runs within a Web server environment. A Java servlet 
takes a request as input, parses the data, performs logic operations, and issues a response back to WAP protocol 
gateway 120. The Java runtime platform pools the Java servlets to simultaneously service many requests. Network 
interface 420 accepts request messages from WAP protocol gateway 120 and passes the information in the request 
to visit object 428 for further processing, visit object 428 passes the result of that processing to network interface 420 

15 for transmission back to the WAP protocol gateway 120. Network interface 420 may also use network adapter 406 to 
exchange data with another user device. 

[0161] Infrastructure objects partition 422 retains the programs that perform administrative and system functions on 
behalf of business logic tier 414. Infrastructure objects partition 422 includes operating system 425, and an object 
oriented software program component for database server interface 430, and system administrator interface 432. 

20 [0162] Business logic tier 41 4 in Fig. 6 includes multiple instances of visit object 428, 428', 428". A separate instance 
of visit object 428 exists for each network interface 420 session. Each visit object 428 is a stateful session object that 
includes a persistent storage area from initiation through termination of the session, not just during a single interaction 
or method call. The persistent storage area retains information associated with the session. 
[0163] When WAP protocol gateway 1 20 sends a metadata vector 1 38 m essage to network server 1 40, the message 

25 is sent to network interface 420 to invoke a method that creates visit object 428 and stores connection information as 
a state in visit object 428. Visit object 428 may, in turn, invoke a method in context inferen ce engine 142 application 
440 to perform a context inference on the metadata vector and return a current context result. 
[0164] When WAP protocol gateway 120 sends a privacy control data 150' message to network server 140, the 
message is sent to network interfa ce 420 to invoke a method that creates visit object 428 and stores connection 

30 information as a state in visit object 428. Visit object 428 may, in turn, invoke a method in privacy control 1 64 application 
442 to update the cached privacy profile 144. 

[0165] When WAP protocol gateway 120 sends a context -activity pair message 190 to network server 140, the 
message is sent to network interface 420 to invoke a method that creates visit object 428 and stores connection infor- 
mation as a state in visit object 428. Vi sit object 428 may, in turn, invoke a method in context -activity pair recommen- 
ds dations application 446. Application 446 compares four types of activities in the context -activity pairs received from 
the wireless device 1 00, with the recommendations in the da tabase 192: [1] past recommendations, [2] past services 
used, [3] prestored service preferences, and [4] special requested service requirements. Application 446 may, in turn 
make a method call to context -activity recommendations usage statistics applicati on 448. 
[01 66] When WAP protocol gateway 1 20 sends a metadata vector message of the user's voice command to network 
40 server 140, the message is sent to network interface 420 to invoke a method that creates visit object 428 and stores 
connection information as a state in visit object 428. Visit object 428 may, in turn, invoke a method in voice recognition 
engine 1 67 application 450 to perform voice recognition on the metadata vector and return a selected service indication 
identifying the recommend service corre sponding to the user's voice command. 

[0167] A description of server programming applications developed with Enterprise Java Beans is provided in the 
45 book by Ed Roman entitled Mastering Enterprise Java Beans , published by John Wiley and Sons, 1999. A descripti 
on of the use of an object model in the design of server applications is provided in the book by Matthew Reynolds 
entitled Beginning E-Commerce , Wrox Press Inc., 2000, (ISBN: 1861003986). Java servlets and the development of 
web site servers is described i n the book by Duane K. Fields, et al. entitled Web Development with Java Server Pages , 
published by Manning Publications Co., 2000. 

so 

Example Wireless Application Protocol (WAP) Embodiment 

[0168] The user's Wireless Application Protocol (WAP) -enabled portable wireless device 100 accesses a small file 
called a deck which is composed of several smaller pages called cards which are small enough to fit into the display 
55 area of the device's browser 102. The small size of the browser 102 and the small file sizes accomm odate the low 
memory constraints of the portable wireless device 1 00 and the low -bandwidth constraints of a wireless network 116. 
The cards are written in the Wireless Markup Language (WML) which is specifically devised for small screens and one 
-hand navigation without a keyboard. The WML language is scaieable from two -line text displays on the browser 1 02 
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of a cellular telephone, up through large LCD screens found on smart phones and personal communicators. The cards 
written in the WML language can include programs written in WMLScript, which is similar to JavaScript, but makes 
minimal demands on memory and CPU power of the device 1 00 because it does not contain many of the unnecessary 
functions found in other scripting languages. 

5 [01 69] The Nokia WAP Client Version 2.0 is a software product containing the components necessary to implement 
the WAP dient on the wireless device 1 00. These components include a Wireless Markup Language (WML) Browser, 
WMLScript engine, Push Subsystem, and Wireless Protocol Stack. The Nokia WAP Client is a source -code product 
that can port and integrate into wireless devices such as mobile phones and wireless PDAs. Application programs 1 06 
stored in the wireless device 1 00 interact with the WAP Client to implement a variety of com munications applications. 

10 Details of the Nokia WAP Client Version 2.0 can be found in the online paper Nokia WAP Client Version 2.0, Product 
Overview , Nokia Internet Communications, 2000, www.nokia.com/corporate/wap. 

[01 70] The WAP Client includes the Wireless Public Key infrastructure (PKI) feature, providing the infrastructure and 
the procedures required for authentication and digital signatures for servers and mobile clients. Wireless PKI is a 
certificate -based system that utilizes public/private key pairs a ssociated with each party involved in a mobile trans- 

15 action. Wireless Identity Module (WIM) is a security token feature of the WAP Client, which includes security features, 
such as the public and private keys and service certificates, needed for user authentication and digital signatures. 
Additionally, it has the ability to perform cryptographic operations to encrypt and decrypt messages. 
[0171] The WAP protocol gateway 120 links the Internet 130 and the wireless network 116. The WAP protocol gate- 
way 120 includes the Wireless Public Key infrastructure (PKI) feature to help provide a secure Internet connection to 

20 the wireless device 100. The WAP protocol gateway 120 enables the WAP -enabled wireless device 100 to access 
Internet applications such as headline news, e xchange rates, sports results, stock quotes, online travel and banking 
services, or to download distinctive ringing tones. 

[01 72] The user's WAP-enabled portable wireless device 1 00 communicates with the wireless access point 1 1 4 and 
can exchange messages for d istances up to several kilometers. The types of wireless networks 116 supported by the 
25 WAP standard Include Cellular Digital Packet Data (CDPD), Code-Division Multiple Access (CDMA), Global System 
for Mobile Communications (GSM), Time Division Multiple Ac cess (TDM A), GPRS, 3G-Broadband, and the like. 
[0173] The overall process of communication between the user's WAP -enabled wireless device (the client) 100, 
through the WAP protocol gateway 120, to the server 140 resembles the way Web pages are served on the In temet 
using the Hypertext Transfer Protocol (HTTP) or World Wide Web protocol: 

30 

[1 ] The user presses a phone key on the user's device 1 00 related to the Uniform Resource Locator (URL) of the 
server 140. 

[2] The user's device 1 00 sends the URL, via the wir eless access point 1 1 4 and the wireless network 1 1 6, to the 
gateway 120 using WAP protocols. 
35 [3] The gateway 120 translates the WAP request into an HTTP request and sends it over the Internet 130 to the 

server 140, via Transmission Control Protocol/ Inter net Protocol (TCP/IP) interfaces. 

[4] The server 140 handles the request just like any other HTTP request received over the Internet. The server 
140 either returns a WML deck or a HyperText Markup Language (HTML) page back to the gateway 120 using 
standar d server programs written, for example in Common Gateway Interface (CGI) programs, Java servlets, or 
40 the like. 

[5] The gateway 1 20 receives the respo nse from the server 1 40 on behalf of the user's device 1 00. If the response 
is an HTML page, it gets trans coded into WML if necessary. Then the WML and WMLScript coding is encoded 
into a byte code that is then sent to the user's device 1 00. 

[6] The user's device 1 00 receives the response in the WML byte code and displays the first card in the deck on 
45 the brow ser 1 02 to the user. 

[0174] In Fig. 1, the protocol gateway 120 includes a WAP protocol stack organized into five different layers. An 
application layer is the wireless application environment, which executes portable applications and services. A session 
layer is the wireless session protocol, which supplies methods for the organized exchange of content between client/ 

50 server applications. A transaction layer is the wireless transaction protocol, which provides methods for performing 
reliable transactions. A s ecurity layer is the wireless transport layer security, which provides authentication, privacy, 
and secure connections between applications. The transport layer is the wireless datagram protocol, which shelters 
the upper layers from the unique requirements of the diverse wireless network protocols, such as CDPD, CDMA, GSM, 
etc. Additional information about the WAP standard and the WAP protocol stack can be found in the book by Charles 

55 Arehart, et al. entitled, Professional WAP , published by Wrox Press Ltd., 2000 (ISBN 1-861004-04-1). 

[0175] Fig. 7A is an exemplary process flow diagram by which the user is afforded the opportunity to define voice 
short -cuts, such as voice tags, for services accessed for the first time on the wireless device 1 00. The process comm 
ences at step 702 in which the user selects or inputs a desired service, such as via URL address. The wireless device 



33 



EP 1 333 650 A2 



1 00 compares the service with past used services at step 704 and determines whether this is the first time the service 
has been accessed at step 706. tf not, the wireless device 100 proceeds to step 720 and accesses the service. If so, 
the wireless device 100 determines whether the user wishes to voice tag the service at step 708. For example, the 
wireless device 100 may prompt the user with a YES or NO request. 

5 [0176] If the user does not wish to voice tag the service, the process proceeds to access the service at step 720. If 
the user desires to voice tag the service, the process proceeds to step 71 0 and requests and receives a user input co 
rresponding to the desired voice tag. For speech independent voice recognition, this user input may simply be a word 
or phrase inputted by key command. At step 71 2, the wireless device 1 00 processes the input data to computer readable 
data suitable for use in comparison in voice recognition processing. At step 714, the wireless device 100 associates 

io the inputted word or phrase, i.e., voice short -cut, to the service or service address. At step 71 8, the wireless device 
100 stores this association in a dat abase, such as the service history log 110 or a dictionary, to enable future use 
thereof as a voice short -cut to the service. The process then continues to step 720 in which the service is accessed. 
The wireless device may further at a step 71 6 send the association to the network server 140 to update the server on 
the new association. 

15 [0177] Fig. 7B is an exemplary process flow diagram by which the user is afforded the opportunity to add or modify 
voice short -cuts, such as voice tags, for accessible services. T he process commences at step 730 in which the 
wireless device 1 00 receives a request from the user to add or modify a voice tag for a past used service. At step 732, 
the wireless device 100 receives a user input identifying the particular used service. T he process proceeds to step 
734 and requests and receives a user input corresponding to the desired voice tag. For speech independent voice 

20 recognition, this user input may simply be a word or phrase inputted by key command. At step 736, the wireless dev 
ice 1 00 processes the input data to computer readable data suitable for use in comparison in voice recognition process- 
ing. At step 738, the wireless device 100 associates the inputted word or phrase, i.e., voice short -cut, to the service 
or service address. At step 740, the wireless device 100 stores this association in a database, such as the service 
history log 110 or a dictionary, to enable future use thereof as a voice short -cut to the service. The process then 

25 continues to step 742 in which the wire less device 1 00 sends the association to the network server 1 40 to update the 
server on the new association. 

[0178] Fig. 7C is an exemplary database or data structure 750 showing the different hierarchical levels of service/ 
sub -service in relations to their voice short-cuts in a tree format. As shown, the voice short-cuts may change depending 
on the level of the service, such as the current level of services requested or already requested. For example, the voice 
30 short -cuts on a first level of service in which "n ews" is requested would be different than the voice short -cuts on a 
different level of service, e.g., In which "stock" has already been requested. Accordingly, the voice short-cuts (or rec- 
ommended services) may change based on which service or level of service is currently being used or requested. The 
available voice short -cuts change, e.g., are narrowed, according to the branch/sub -branch of the services being 
requested and, thus, vary according to the level of service. 

35 

VOICE SHORT -CUT EXAMPLE #1 

[0179] An operational example of wireless device 100 employing, locally or remotely, a service recommendation 
subsystem in combination with voice recognition subsystem is discussed below with reference to Figs. 1 and 3J through 

40 3L. A user initiates a browsing operation via the browser 102 to trigger a recommendation process to be performed 
locally at the wireless device 1 00 or remotely at network server 140. In either case, a subset of recommended digital 
services are determined from a plurality of digital services (which may be quite a large set) based on user-related filter 
criteria, such as a current context. The subset of recommended services reflects those services the user would likely 
desire, preferably with a high probability, in the current context. 

45 [0180] For instance, a user, such as a business person, operating his or her wireless device 1 00 between 1 1 :00AM 
-2:00PM or on Wall St. or during the daytime or at a temperature between 15°C - 25°C or at a speed between 0 - 50 
kph or a combination thereof may be prov ided with the following recommended services: 

so Host: wap.yahooMobile.com 

Services (address): 

-world news (/news/world wml) 
-business news (/news/business. wml) 
-Fl news (/sports/fl /news. wml) 

55 
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Host: wap.business.com 
Services (address): 

-on-line news (/online, wml) 

-main news (/index, wml) 

-stock quotes: Nokia (/stocks/quotes.pl?ticker=NOK) 

Host: wap.fl -forum.com 
Services (address): 

-news (/news.wml) 

-results (/results.wml) 

-table (/table.wml) 

Host: wap.weatherOnLine.com: 
Services: 

-Helsinki tomorrow (/forecastpl?dty=Helsinki&day==H-l) 

The recommended services may be outputted, audibly and/or visibly, in a menu form (if desired) to the user, or may 
be transparent to the user (e.g., not outputted). Thereafter, the user gives the following voice browsing c ommand 
(host, service): f I -forum, news". The voice recognition engine identifies the host and service commands by comparing 
the commands to the limited set of most probable host and service alternatives and informs the browser 102 which 
service should be loaded, e.g., wap.fl -forum.com/news.wml. 

[0181] One example of such a menu is shown in Fig. 3J in which both the host and service names are displayed for 
selection by the user. Another example of such a menu is shown in Figs 3K and 3L in which Fig. 3K shows an initial 
menu of the host names of the recommended services and Fig. 3L shows a subsequent menu of the service name of 
the selected host name. In this example, the user may access the home page of a service site by an initial voice 
command, and then browse the service extensions of the site through addition voice commands. Such an arrangement 
provides a multi -layered voice-access arrangement to reduce further the range of voice short -cuts to be processed, 
as well as providing multi -modal input functionality in initial service access and subsequent browsing. 
[0182] The voice recognition can be performed without voice tags or optionally the voice recognition task can be 
made easier by pre -loading voice tags from the appropriate services. Voice tags can be used by the voice recognition 
engine to identify the spoken host and service commands. The number of alternatives presented to the voice recognition 
engine by the recommendation sub -system depends on the capability of the voice recognition engine. In some cases, 
the alternatives presented to the voice recognition engine could include all the services the user has ever visited. The 
recommendation sub -system may also attach prior service access probabilities for each service. 

VOICE SHORT -CUT EXAMPLE #2 

[0183] In a further example, a voice command may match multiple voice short -cuts to different recommended serv- 
ices. In such a case, wireless device 100 may provide the user with a list of matching short-cuts from which the user 
can select the correct short -cut to access the desired service. 

[0184] For instance, a user operating a wireless device 1 00 has been actively checking stock quotes for the following 
three stocks: Nokia, Ericsson, Motorola. The voice short -cuts for these prior services may be the following (or possibly 
the corresponding phonetic expression): 

• Yahoo stock quote Nokia 

• Yahoo stock quote Ericsson 

• Yahoo stock quote Motorola 

The user inputs a voice command, "Yahoo stock quote", to the wireless device 1 00. Since the voice command matches 
partly with three diffe rent short-cuts, the wireless device 1 00 outputs, visually or audibly, a list of matching short -cuts 
to the user, as follows: 

• Yahoo stock quote Nokia 

• Yahoo stock quote Ericsson 

• Yahoo stock quote Motorola 
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The identification of the short -cuts identifies the recommended services and, as importantly, allows the user to become 
familiar with the voice short -cuts for various services. 

[01 85] Thereafter, the user may select a correct or desired alternative from the list of matching short-cuts, and obtains 
the selected service. The user may make the selection via voice command, key command or other well -known user 
input command. For example, the user may employ the voice command, -Nokia 0 or "Yahoo stock quote Nokia", to 
obtain the stock quote for Nokia from the Yahoo site, or may enter a key command corresponding to desired service 
from the list. 

[01 86] In another example, the user has been actively checking, via the wireless device 1 00, the following web pages: 

• Yahoo news business 

• Yahoo news world 

• Yahoo news entertainment 

• Excite news business 

• Excite news world 

The user inputs a voice command, "news", to the wireless device 1 00. Since the voice command matches partly with 
five different short -cuts, the wireless device 1 00 outputs, visually or audibly, a list of matching sho rt-cuts to the user, 
as follows. 

20 • Yahoo news business 

• Yahoo news world 

• Yahoo news entertainment 

• Excite news business 

• Excite news world 

25 

[01 87] Alternatively, if the user inputs a voice command, "Yahoo news", the wireless device 1 00 may output, visually 
or audibly, a list of three matching short -cuts to the user as follows: 

• Yahoo news business 
30 • Yahoo news world 

• Yahoo news entertainment 

[0188] In another alternative, if the user inputs a voice command, "news business", the wireless device 1 00 may 
output, visually or audibly , a list of two matching short -cuts to the user as follows: 

35 

• Yahoo news business 

• Excite news business 

Accordingly, in the situation in which a voice command matches a plurality of the recommended services, the wireless 
40 device 1 00 may be configured to output an indication of the matched services for selection by the user. The indication 
of the matched services may take the form of voice short-cuts corresponding thereto. 

[01 89] Although a specific embodiment of the feature has been disclosed, it will be understood by those having skill 
in the art that changes can be made to the specific embodiment without departing from the spirit and the scope of the 
feature. 

45 [0190] Although specific embodiments of the invention have been disclosed, it will be understood by those having 
sk ill in the art that changes can be made to that the specific embodiments without departing from the spirit and the 
scope of the invention. 



so Claims 

1 . A method of enabling user access to services through a wireless device (1 00) of a user, the method compr ising: 

recommending to a user a subset of services from a plurality of services available to the user, each recom- 
55 mended service of the subset having at least one voice short -cut associated therewith; and 

selecting a service to be accessed through the user* s wireless device from the subset of services according 
to a voice command by the user corresponding to the voice short -cut of the service. 
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2. A method according to claim 1 , wherein the plurality of services comprises services previously accessed by the 
user. 

3. A method according to claim 1 or 2, wherein the recommended services are transparent to the user. 

5 

4. A method according to any preceding claim, further comprising visually outputting visual information corresponding 
to the subset of recommended services to the user. 

5. A method according to claim 4, wherein the visual information includes identification of a voice short -cut for each 
io service of the subset of services. 

6. A method according to claim 5, wherein the visual information includes an icon to notify the user of the availability 
of voice access of the recommended services. 

15 7. A method according any preceding claim, further comprising audibly outputting audio information corresponding 
to the subset of recommended services to the user. 

8. A method according to claim 7, wherein the audio information includes identification of a voice short -cut for each 
service of the subset of recommended services. 

20 

9. A method according any preceding claim, wherein the recommending determines the subset of recommended 
services based on the user -related filter criteria. 

10. A method according to any preceding claim, wherein the recommending determines the subset of recommended 
25 services based on a current context of the user. 

11. A method according to c laim 10, wherein the current context is inferred based on at least one of a temporal 
variable, a position variable and a selected profile of the device. 

30 12. A method according to any preceding claim, further comprising determining the current context bas ed on a current 
sensed environment of the wireless device. 

13. A method according to any preceding claim, wherein the recommending determines the subset of recommended 
services based on a service usage history or preference of the user. 

35 

14. A method according to any preceding claim, wherein the recommending determines the subset of recommended 
services based on the current environment of the wireless device sensed by one or more sensors. 

15. A method according to claim 14, wherein the sensor is a p ositioning sensor (122), a compass (126), a touch 
40 sensor (124), an audio sensor (125), a light sensor (128), and/or a temperature sensor (132). 

16. A method according to any preceding claim, further comprising obtaining voice short-cuts for a service in an XML 
format. 

45 17. A method according to any preceding claim, further comprising assigning temporary voice short-cuts to the subset 
of recommended services. 

18. A method according to any preceding claim, further comprising generating a voice short-cut for a service from the 
plurality of services based on metadata associated with the service. 

50 

19. A method according to any preceding claim, further comprising enabling the user to predefine a voice short -cut 
for a service from the plurality of services, and/or enabling the user to add or modify voice short -cuts for any one 
of the plurality of services. 

55 20. A method according to any preceding claim, wherein a voice short -cut for a service of the plurality of services is 
predefined by the service provide r. 

21. A method according to any preceding claim, further comprising receiving a voice short-cut for a service from a 
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remote location, across a wireless network (116). 
22. A method according to claim 21 , wherein: 

the voice short-cut for a service is received from a remote location, across an ad hocwireless network including 
the wireless device; and/or k ,. 4H « 

the voice short-cut for a service is received from a voice tag registry (172), across a wireless network (116). 

23 Amethodaccordingtoanyprecedingclaim,whereintheselectingcomprisesperf^^^ 
ing to identify the service with a voice short -cut matching the voice command. 

24. A method according to claim 23, wherein: 

voice recognition processing is performed by comparing the voice command only to voice shortcuts of the 

^BT^^nta!!r^^^!^ 0 ta performed to identify the service with a voice short-cut matching the voice 
command according to a priority of the recommended serv ices; and/or 

voice recognition processing is performed by the wireless device; and/or ltaAcaniina 
voice recognition processing is performed at a remote server and information identrfymg the selected serves 
from the subset of recommended services is provided by the remote server to the w.reless device. 

25. A method according to any preceding claim, wherein: 

the recommending of a subset of services is performed by the wireless device; anj/°r 

the recommending of a subset of services is performed at a remo te server and information identifying the 

subset of recommended services is provided by the remote server to the wireless device. 

26. A method according to any preceding claim, wherein: 

the selecting of a service is performed by the wireless device; a nd/or a . mAm frnm 

the selecting of a service is performed at a remote server and information identrfymg the selected serv.ce from 
the subset of recommended services is provided by the remote server to the wireless device. 

27. A method according to any preceding claim, further comprising: 

filtering down the subset of recommended services for selection according to past recommendations to the 
fiften : ng n down the subset of recommended services for selection according to user-defined filter categori es. 

28. A method according to any preceding claim, further comprising accessing the selected service using the wireless 
device across a wireless network. 

29. A method according to claim 28, further comprising: 

enabling multi-modal input, including at least voice input, to browse the accessed service; and/or 

enabling mufti-modal input selection, including at least by voice, of a service to be from the subset of recom- 

mended services. 

30. A method according to any preceding claim, wherein the voice command matches a plurality of the recommended 
services, further comprising outputting an indication of the matched services for selection by the user. 

31 . A method according to claim 30. wherein the indication of the matched services comprises voice sho rt<uts cor- 
responding to thereto. 

32. A method according to any preceding claim, further comprising maintaining one or more databases of information 
corresponding to services and associated voice short-cuts. 

33. A method according to any preceding cla im, further comprising interacting with at least one of a user input device 
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and a user output device across a wireless short-range link. 

34. A method according to any preceding claim, wherein the voice short -cuts of the recommended services change 
hierar chically according to a level of service. 

5 

35. A method of facilitating multimodal access to services through a wireless device (100) of a user, the method com- 
prising: 

recommending to a user a subset of services from a plurality of services available to the user, each recom- 
w mended service of the subset having at least one voice short -cut associated therewith; and 

selecting a service to be accessed through the user's wireless device from the subset of services according 
to a voice command by the user correspo nding to the voice short -cut of the service. 

36. A wireless device (100) comprising: 

a voice input device (103); 
output device (102); 

wireless interface (206) for communicating across at least a wireless network; and 
at least one processor (210) for recom mending to a user a subset of services from a plurality of services 
available to the user, each recommended service of the subset having at least one voice short-cut associated 
therewith, and for selecting a service to be accessed through the user's wireless device from the subset of 
services according to the user's voice command received from the voice input device corresponding to the 
voice short -cut of the service. 

25 37. A network system for enabling user access to services through a wireless device of a user, the system comprising: 

a wireless device (100), a server (140) and a wireless network infrastructure (116) to enable communication 
between the wireless device and the server, the wireless device and the server cooperating (1) to determine 
a subset of services from a plurality of services available to the user, each recommended service of the subset 
30 having at least one voice short -cut associated therewith, and (2) to select a service to be accessed through 

the wireless device from the subset of services according to the user's voice command, inputted to the wireless 
device, corresponding to the voice short -cut of the service. 

38. A system for enabling user access to services through a wireless device of a user, the system comprising: 

a plurality of sensors (122, 124, 1 28, 1 26, 1 25, 1 32) for sensing an environment of a wireless device operated 
by a user; 

a context engine (115) for determining a current context based on the sensed environment; 
a recommendation engine (1 1 2) for recommending to the user a subset of services from a plurality of services 
previously used by the user, each recommended service of the subset having at least one voice short -cut 
associated therewith; 

a voice recognition engine (113) for receiving a voice command from the user a nd comparing the user's voice 
command to the voice short -cuts of the recommended service; and 

a browser (102) for accessing a service, from the subset of recommended services, with a voice short-cut 
matching the voice command. 

39. A computer-readable medium encoded with processing instructions for implementing a method of enabling user 
access to services , performed by a computer, the method comprising: 

so recommending to a user a subset of services from a plurality of services available to the user, each recom- 

mended service of the subset having at least one voice short -cut associated therewith; and 
selecting a service to be accessed through the user's wireless device from the subset of services according 
to a voice command by the user corresponding to the v oice short-cut of the service. 
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FIG. 6 
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